@_tc/template-core 0.0.1-bate.8 → 0.0.1-bate.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (546) hide show
  1. package/{app → cjs/app}/controller/base.d.ts +1 -2
  2. package/{app → cjs/app}/controller/base.js +0 -2
  3. package/{app → cjs/app}/controller/project.d.ts +1 -2
  4. package/cjs/app/controller/project.js +50 -0
  5. package/{app → cjs/app}/controller/view.d.ts +1 -2
  6. package/cjs/app/data/signKey.d.ts +1 -0
  7. package/cjs/app/extend/db.d.ts +2 -0
  8. package/cjs/app/extend/db.js +12 -0
  9. package/cjs/app/extend/generateErrorMessage.d.ts +7 -0
  10. package/{app → cjs/app}/extend/generateErrorMessage.js +3 -0
  11. package/cjs/app/extend/logger.d.ts +11 -0
  12. package/cjs/app/extend/parsingParamsOnUrl.d.ts +2 -0
  13. package/{app → cjs/app}/extend/render-view.d.ts +1 -2
  14. package/{app → cjs/app}/middleware/api-params-verify.d.ts +1 -2
  15. package/{app → cjs/app}/middleware/api-sign-verify.d.ts +1 -2
  16. package/{app → cjs/app}/middleware/error-handle.d.ts +1 -2
  17. package/{app → cjs/app}/middleware/project-handler.d.ts +1 -2
  18. package/cjs/app/middleware.d.ts +5 -0
  19. package/{app → cjs/app}/middleware.js +23 -1
  20. package/cjs/app/router/project.d.ts +4 -0
  21. package/cjs/app/router/view.d.ts +4 -0
  22. package/cjs/app/router-schema/project.d.ts +3 -0
  23. package/cjs/app/service/bese.d.ts +10 -0
  24. package/cjs/app/service/project.d.ts +27 -0
  25. package/cjs/app/service/project.js +42 -0
  26. package/cjs/app/type.d.ts +2 -0
  27. package/cjs/app/typings.d.ts +49 -0
  28. package/cjs/app/view/entry.tpl +30 -0
  29. package/cjs/bundler/dev.d.ts +1 -0
  30. package/{packages/ui/react/components/Form/SchemeForm/data.js → cjs/bundler/dev.js} +30 -9
  31. package/cjs/bundler/index.d.ts +1 -0
  32. package/cjs/bundler/index.js +18 -0
  33. package/cjs/bundler/prod.d.ts +1 -0
  34. package/cjs/bundler/prod.js +19 -0
  35. package/cjs/bundler/utils.d.ts +7 -0
  36. package/cjs/bundler/utils.js +127 -0
  37. package/cjs/index.d.ts +28 -0
  38. package/cjs/packages/core/env.d.ts +15 -0
  39. package/cjs/packages/core/index.d.ts +6 -0
  40. package/{packages → cjs/packages}/core/index.js +24 -0
  41. package/cjs/packages/core/loader/config.d.ts +9 -0
  42. package/{packages → cjs/packages}/core/loader/config.js +14 -0
  43. package/cjs/packages/core/loader/controller.d.ts +17 -0
  44. package/{packages → cjs/packages}/core/loader/controller.js +23 -0
  45. package/cjs/packages/core/loader/extend.d.ts +8 -0
  46. package/{packages → cjs/packages}/core/loader/extend.js +8 -0
  47. package/cjs/packages/core/loader/middleware.d.ts +11 -0
  48. package/cjs/packages/core/loader/middleware.js +38 -0
  49. package/cjs/packages/core/loader/model.d.ts +36 -0
  50. package/{packages → cjs/packages}/core/loader/model.js +43 -0
  51. package/cjs/packages/core/loader/router-schema.d.ts +18 -0
  52. package/{packages → cjs/packages}/core/loader/router-schema.js +16 -0
  53. package/{packages → cjs/packages}/core/loader/router.d.ts +5 -1
  54. package/{packages → cjs/packages}/core/loader/router.js +20 -3
  55. package/cjs/packages/core/loader/service.d.ts +17 -0
  56. package/{packages → cjs/packages}/core/loader/service.js +14 -0
  57. package/cjs/packages/core/paths.d.ts +11 -0
  58. package/{packages → cjs/packages}/core/types.d.ts +1 -1
  59. package/{packages → cjs/packages}/utils/getAllFilesInFolder.d.ts +5 -1
  60. package/cjs/packages/utils/getAllFnReturnValue.d.ts +0 -0
  61. package/cjs/packages/utils/getAllFnReturnValue.js +6 -0
  62. package/cjs/packages/utils/index.d.ts +4 -0
  63. package/{packages → cjs/packages}/utils/loadFile.d.ts +6 -1
  64. package/{packages → cjs/packages}/utils/loadFile.js +9 -0
  65. package/cjs/packages/utils/path.d.ts +24 -0
  66. package/{packages → cjs/packages}/utils/path.js +14 -0
  67. package/cjs/packages/utils/runFileFn.d.ts +5 -0
  68. package/cjs/typings/type.d.ts +4 -0
  69. package/esm/app/controller/base.d.ts +14 -0
  70. package/esm/app/controller/base.js +21 -0
  71. package/esm/app/controller/project.d.ts +12 -0
  72. package/{app → esm/app}/controller/project.js +3 -8
  73. package/esm/app/controller/view.d.ts +9 -0
  74. package/esm/app/controller/view.js +12 -0
  75. package/esm/app/data/signKey.js +1 -0
  76. package/esm/app/extend/db.js +9 -0
  77. package/esm/app/extend/generateErrorMessage.js +12 -0
  78. package/esm/app/extend/logger.js +37 -0
  79. package/esm/app/extend/parsingParamsOnUrl.js +20 -0
  80. package/esm/app/extend/render-view.d.ts +5 -0
  81. package/esm/app/extend/render-view.js +16 -0
  82. package/esm/app/middleware/api-params-verify.d.ts +6 -0
  83. package/esm/app/middleware/api-params-verify.js +58 -0
  84. package/esm/app/middleware/api-sign-verify.d.ts +6 -0
  85. package/esm/app/middleware/api-sign-verify.js +23 -0
  86. package/esm/app/middleware/error-handle.d.ts +6 -0
  87. package/esm/app/middleware/error-handle.js +31 -0
  88. package/esm/app/middleware/project-handler.d.ts +5 -0
  89. package/esm/app/middleware/project-handler.js +19 -0
  90. package/esm/app/middleware.js +55 -0
  91. package/esm/app/router/project.js +6 -0
  92. package/esm/app/router/view.js +3 -0
  93. package/esm/app/router-schema/project.js +31 -0
  94. package/esm/app/service/bese.js +12 -0
  95. package/{app → esm/app}/service/project.js +6 -10
  96. package/esm/app/type.js +1 -0
  97. package/esm/app/typings.js +1 -0
  98. package/esm/app/view/entry.tpl +30 -0
  99. package/esm/bundler/dev.d.ts +2 -0
  100. package/esm/bundler/dev.js +29 -0
  101. package/esm/bundler/index.d.ts +2 -0
  102. package/esm/bundler/index.js +14 -0
  103. package/esm/bundler/prod.d.ts +2 -0
  104. package/esm/bundler/prod.js +16 -0
  105. package/esm/bundler/utils.d.ts +8 -0
  106. package/esm/bundler/utils.js +85 -0
  107. package/esm/index.js +13 -0
  108. package/esm/packages/core/env.js +23 -0
  109. package/esm/packages/core/index.js +109 -0
  110. package/esm/packages/core/loader/config.d.ts +10 -0
  111. package/esm/packages/core/loader/config.js +43 -0
  112. package/esm/packages/core/loader/controller.d.ts +18 -0
  113. package/esm/packages/core/loader/controller.js +38 -0
  114. package/esm/packages/core/loader/extend.d.ts +9 -0
  115. package/esm/packages/core/loader/extend.js +39 -0
  116. package/esm/packages/core/loader/middleware.d.ts +12 -0
  117. package/esm/packages/core/loader/middleware.js +36 -0
  118. package/esm/packages/core/loader/model.d.ts +37 -0
  119. package/esm/packages/core/loader/model.js +127 -0
  120. package/esm/packages/core/loader/router-schema.d.ts +19 -0
  121. package/esm/packages/core/loader/router-schema.js +33 -0
  122. package/esm/packages/core/loader/router.d.ts +9 -0
  123. package/esm/packages/core/loader/router.js +57 -0
  124. package/esm/packages/core/loader/service.d.ts +18 -0
  125. package/esm/packages/core/loader/service.js +28 -0
  126. package/esm/packages/core/paths.js +6 -0
  127. package/esm/packages/core/types.d.ts +75 -0
  128. package/esm/packages/core/types.js +1 -0
  129. package/esm/packages/utils/getAllFilesInFolder.d.ts +10 -0
  130. package/esm/packages/utils/getAllFilesInFolder.js +8 -0
  131. package/esm/packages/utils/getAllFnReturnValue.js +6 -0
  132. package/esm/packages/utils/index.js +4 -0
  133. package/esm/packages/utils/loadFile.d.ts +21 -0
  134. package/esm/packages/utils/loadFile.js +63 -0
  135. package/esm/packages/utils/path.d.ts +25 -0
  136. package/esm/packages/utils/path.js +27 -0
  137. package/esm/packages/utils/runFileFn.js +1 -0
  138. package/esm/typings/type.d.ts +5 -0
  139. package/esm/typings/type.js +1 -0
  140. package/fe/frontend/main.js +6 -0
  141. package/fe/packages/ui/react/assets/table/no-result.svg +5 -0
  142. package/{packages → fe/packages}/ui/react/components/Button/Button.d.ts +24 -0
  143. package/fe/packages/ui/react/components/Button/Button.js +42 -0
  144. package/{packages → fe/packages}/ui/react/components/Button/SumbitButton.d.ts +4 -0
  145. package/fe/packages/ui/react/components/Button/SumbitButton.js +32 -0
  146. package/fe/packages/ui/react/components/Button/index.js +2 -0
  147. package/{packages → fe/packages}/ui/react/components/Checkbox/Checkbox.js +9 -12
  148. package/fe/packages/ui/react/components/Checkbox/index.js +1 -0
  149. package/{packages → fe/packages}/ui/react/components/ConfirmDialog.d.ts +8 -0
  150. package/fe/packages/ui/react/components/ConfirmDialog.js +9 -0
  151. package/fe/packages/ui/react/components/DataTable/ActionBtn.js +13 -0
  152. package/{packages → fe/packages}/ui/react/components/DataTable/data-table.d.ts +19 -0
  153. package/{packages → fe/packages}/ui/react/components/DataTable/data-table.js +23 -26
  154. package/{packages → fe/packages}/ui/react/components/Date/Calendar.d.ts +13 -0
  155. package/fe/packages/ui/react/components/Date/Calendar.js +215 -0
  156. package/{packages → fe/packages}/ui/react/components/Date/Date.d.ts +10 -0
  157. package/fe/packages/ui/react/components/Date/Date.js +178 -0
  158. package/fe/packages/ui/react/components/Date/DateTestPage.js +29 -0
  159. package/fe/packages/ui/react/components/Date/LocaleContext.d.ts +6 -0
  160. package/fe/packages/ui/react/components/Date/LocaleContext.js +8 -0
  161. package/{packages → fe/packages}/ui/react/components/Date/LocaleProvider.d.ts +11 -0
  162. package/fe/packages/ui/react/components/Date/LocaleProvider.js +24 -0
  163. package/fe/packages/ui/react/components/Date/TimePicker.js +76 -0
  164. package/fe/packages/ui/react/components/Date/data.js +4 -0
  165. package/{packages → fe/packages}/ui/react/components/Date/dateLocaleStore.d.ts +6 -0
  166. package/fe/packages/ui/react/components/Date/dateLocaleStore.js +14 -0
  167. package/fe/packages/ui/react/components/Date/index.js +5 -0
  168. package/{packages → fe/packages}/ui/react/components/Date/locales.d.ts +19 -0
  169. package/{packages → fe/packages}/ui/react/components/Date/locales.js +16 -6
  170. package/fe/packages/ui/react/components/Dropdown.js +54 -0
  171. package/{packages → fe/packages}/ui/react/components/Form/Form.d.ts +6 -0
  172. package/fe/packages/ui/react/components/Form/Form.js +8 -0
  173. package/{packages → fe/packages}/ui/react/components/Form/FormItem.d.ts +21 -0
  174. package/fe/packages/ui/react/components/Form/FormItem.js +43 -0
  175. package/fe/packages/ui/react/components/Form/SchemeForm/data.js +8 -0
  176. package/{packages → fe/packages}/ui/react/components/Form/SchemeForm/index.d.ts +93 -0
  177. package/fe/packages/ui/react/components/Form/SchemeForm/index.js +69 -0
  178. package/fe/packages/ui/react/components/Form/index.js +4 -0
  179. package/fe/packages/ui/react/components/Form/useForm.js +1 -0
  180. package/{packages → fe/packages}/ui/react/components/ImagePreview/ImagePreview.js +46 -41
  181. package/{packages → fe/packages}/ui/react/components/ImagePreview/PreviewImage.d.ts +3 -0
  182. package/fe/packages/ui/react/components/ImagePreview/PreviewImage.js +25 -0
  183. package/fe/packages/ui/react/components/ImagePreview/index.js +2 -0
  184. package/{packages → fe/packages}/ui/react/components/Input/Input.d.ts +20 -0
  185. package/fe/packages/ui/react/components/Input/Input.js +60 -0
  186. package/fe/packages/ui/react/components/Input/index.js +1 -0
  187. package/{packages → fe/packages}/ui/react/components/Label/Label.d.ts +29 -0
  188. package/fe/packages/ui/react/components/Label/Label.js +35 -0
  189. package/fe/packages/ui/react/components/Label/index.js +2 -0
  190. package/{packages → fe/packages}/ui/react/components/Message/Message.d.ts +7 -0
  191. package/fe/packages/ui/react/components/Message/Message.js +55 -0
  192. package/{packages → fe/packages}/ui/react/components/Message/MessageManager.js +26 -21
  193. package/fe/packages/ui/react/components/Message/data.js +1 -0
  194. package/fe/packages/ui/react/components/Message/index.js +1 -0
  195. package/{packages → fe/packages}/ui/react/components/Modal/Modal.d.ts +6 -0
  196. package/fe/packages/ui/react/components/Modal/Modal.js +51 -0
  197. package/{packages → fe/packages}/ui/react/components/Modal/ModalManager.d.ts +12 -0
  198. package/{packages → fe/packages}/ui/react/components/Modal/ModalManager.js +22 -23
  199. package/fe/packages/ui/react/components/Modal/index.js +2 -0
  200. package/{packages → fe/packages}/ui/react/components/Pagination.d.ts +7 -0
  201. package/{packages → fe/packages}/ui/react/components/Pagination.js +19 -15
  202. package/{packages → fe/packages}/ui/react/components/Search/Search.d.ts +3 -0
  203. package/fe/packages/ui/react/components/Search/Search.js +12 -0
  204. package/fe/packages/ui/react/components/Search/index.js +1 -0
  205. package/{packages → fe/packages}/ui/react/components/Select/Select.d.ts +2 -0
  206. package/fe/packages/ui/react/components/Select/Select.js +180 -0
  207. package/fe/packages/ui/react/components/Select/index.js +1 -0
  208. package/{packages → fe/packages}/ui/react/components/Skeleton/Skeleton.d.ts +15 -0
  209. package/fe/packages/ui/react/components/Skeleton/Skeleton.js +31 -0
  210. package/fe/packages/ui/react/components/Skeleton/index.js +1 -0
  211. package/fe/packages/ui/react/components/Switch/Switch.js +20 -0
  212. package/fe/packages/ui/react/components/Switch/index.js +1 -0
  213. package/{packages → fe/packages}/ui/react/components/TableSearch/TableSearch.d.ts +37 -0
  214. package/{packages → fe/packages}/ui/react/components/TableSearch/TableSearch.js +22 -23
  215. package/fe/packages/ui/react/components/TableSearch/index.js +1 -0
  216. package/fe/packages/ui/react/components/TableSearch/lang.js +23 -0
  217. package/fe/packages/ui/react/components/TableSearch/tableSearchLocaleStore.js +11 -0
  218. package/{packages → fe/packages}/ui/react/components/Textarea.d.ts +40 -0
  219. package/fe/packages/ui/react/components/Textarea.js +35 -0
  220. package/{packages → fe/packages}/ui/react/components/Tooltip.d.ts +16 -0
  221. package/{packages → fe/packages}/ui/react/components/Tooltip.js +26 -16
  222. package/{packages → fe/packages}/ui/react/components/TreeSelect.d.ts +6 -0
  223. package/{packages → fe/packages}/ui/react/components/TreeSelect.js +27 -24
  224. package/{packages → fe/packages}/ui/react/components/Upload/ImageUpload.js +11 -14
  225. package/{packages → fe/packages}/ui/react/components/Upload/Upload.d.ts +27 -0
  226. package/fe/packages/ui/react/components/Upload/Upload.js +5 -0
  227. package/fe/packages/ui/react/components/Upload/index.js +2 -0
  228. package/fe/packages/ui/react/components/breadcrumb.js +78 -0
  229. package/{packages → fe/packages}/ui/react/components/hooks/useInputController.d.ts +3 -0
  230. package/{packages → fe/packages}/ui/react/components/hooks/useInputController.js +15 -12
  231. package/fe/packages/ui/react/components/index.js +23 -0
  232. package/fe/packages/ui/react/components/table.js +20 -0
  233. package/fe/packages/ui/react/components/testPage/index.js +118 -0
  234. package/fe/packages/ui/react/hooks/useBreadcrumb.js +2 -0
  235. package/fe/packages/ui/react/hooks/useInit.js +9 -0
  236. package/fe/packages/ui/react/hooks/useLanguage.js +4 -0
  237. package/{packages → fe/packages}/ui/react/hooks/usePagination.js +7 -13
  238. package/fe/packages/ui/react/index.js +4 -0
  239. package/fe/packages/ui/react/lib/export.d.ts +66 -0
  240. package/{packages → fe/packages}/ui/react/lib/export.js +52 -49
  241. package/fe/packages/ui/react/lib/utils.d.ts +34 -0
  242. package/{packages → fe/packages}/ui/react/lib/utils.js +33 -15
  243. package/fe/packages/ui/react/locales/index.js +6 -0
  244. package/{packages → fe/packages}/ui/react/stores/breadcrumb.js +6 -7
  245. package/{packages → fe/packages}/ui/react/stores/language.js +14 -17
  246. package/fe/packages/ui/react/types/index.js +1 -0
  247. package/package.json +31 -12
  248. package/app/controller/base.d.ts.map +0 -1
  249. package/app/controller/project.d.ts.map +0 -1
  250. package/app/controller/view.d.ts.map +0 -1
  251. package/app/data/signKey.d.ts.map +0 -1
  252. package/app/extend/db.d.ts.map +0 -1
  253. package/app/extend/db.js +0 -7
  254. package/app/extend/generateErrorMessage.d.ts.map +0 -1
  255. package/app/extend/logger.d.ts.map +0 -1
  256. package/app/extend/parsingParamsOnUrl.d.ts.map +0 -1
  257. package/app/extend/render-view.d.ts.map +0 -1
  258. package/app/middleware/api-params-verify.d.ts.map +0 -1
  259. package/app/middleware/api-sign-verify.d.ts.map +0 -1
  260. package/app/middleware/error-handle.d.ts.map +0 -1
  261. package/app/middleware/project-handler.d.ts.map +0 -1
  262. package/app/middleware.d.ts.map +0 -1
  263. package/app/pages/main.d.ts.map +0 -1
  264. package/app/pages/main.js +0 -9
  265. package/app/router/project.d.ts.map +0 -1
  266. package/app/router/view.d.ts.map +0 -1
  267. package/app/router-schema/project.d.ts.map +0 -1
  268. package/app/service/bese.d.ts.map +0 -1
  269. package/app/service/project.d.ts.map +0 -1
  270. package/app/type.d.ts.map +0 -1
  271. package/app/typings.d.ts.map +0 -1
  272. package/app/vite/config/base.d.ts +0 -6
  273. package/app/vite/config/base.js +0 -96
  274. package/app/vite/config/data.d.ts +0 -3
  275. package/app/vite/config/data.js +0 -11
  276. package/app/vite/config/dev.d.ts +0 -11
  277. package/app/vite/config/dev.js +0 -15
  278. package/app/vite/config/prod.d.ts +0 -17
  279. package/app/vite/config/prod.js +0 -34
  280. package/app/vite/dev.d.ts +0 -2
  281. package/app/vite/dev.js +0 -29
  282. package/app/vite/index.d.ts +0 -1
  283. package/app/vite/index.js +0 -13
  284. package/app/vite/package.json +0 -10
  285. package/app/vite/prod.d.ts +0 -1
  286. package/app/vite/prod.js +0 -82
  287. package/index.d.ts.map +0 -1
  288. package/model/index.d.ts +0 -2
  289. package/model/index.d.ts.map +0 -1
  290. package/model/index.js +0 -6
  291. package/model/test.d.ts +0 -6
  292. package/model/test.d.ts.map +0 -1
  293. package/model/test.js +0 -5
  294. package/model/test2.d.ts +0 -6
  295. package/model/test2.d.ts.map +0 -1
  296. package/model/test2.js +0 -5
  297. package/packages/core/env.d.ts.map +0 -1
  298. package/packages/core/index.d.ts.map +0 -1
  299. package/packages/core/loader/config.d.ts +0 -4
  300. package/packages/core/loader/config.d.ts.map +0 -1
  301. package/packages/core/loader/controller.d.ts +0 -4
  302. package/packages/core/loader/controller.d.ts.map +0 -1
  303. package/packages/core/loader/extend.d.ts +0 -4
  304. package/packages/core/loader/extend.d.ts.map +0 -1
  305. package/packages/core/loader/middleware.d.ts +0 -4
  306. package/packages/core/loader/middleware.d.ts.map +0 -1
  307. package/packages/core/loader/middleware.js +0 -15
  308. package/packages/core/loader/model.d.ts +0 -15
  309. package/packages/core/loader/model.d.ts.map +0 -1
  310. package/packages/core/loader/router-schema.d.ts +0 -4
  311. package/packages/core/loader/router-schema.d.ts.map +0 -1
  312. package/packages/core/loader/router.d.ts.map +0 -1
  313. package/packages/core/loader/service.d.ts +0 -4
  314. package/packages/core/loader/service.d.ts.map +0 -1
  315. package/packages/core/paths.d.ts.map +0 -1
  316. package/packages/core/types.d.ts.map +0 -1
  317. package/packages/ui/react/components/Button/Button.d.ts.map +0 -1
  318. package/packages/ui/react/components/Button/Button.js +0 -35
  319. package/packages/ui/react/components/Button/SumbitButton.d.ts.map +0 -1
  320. package/packages/ui/react/components/Button/SumbitButton.js +0 -31
  321. package/packages/ui/react/components/Button/index.d.ts.map +0 -1
  322. package/packages/ui/react/components/Button/index.js +0 -20
  323. package/packages/ui/react/components/Checkbox/Checkbox.d.ts.map +0 -1
  324. package/packages/ui/react/components/Checkbox/index.d.ts.map +0 -1
  325. package/packages/ui/react/components/Checkbox/index.js +0 -17
  326. package/packages/ui/react/components/ConfirmDialog.d.ts.map +0 -1
  327. package/packages/ui/react/components/ConfirmDialog.js +0 -12
  328. package/packages/ui/react/components/DataTable/ActionBtn.d.ts.map +0 -1
  329. package/packages/ui/react/components/DataTable/ActionBtn.js +0 -17
  330. package/packages/ui/react/components/DataTable/data-table.d.ts.map +0 -1
  331. package/packages/ui/react/components/Date/Calendar.d.ts.map +0 -1
  332. package/packages/ui/react/components/Date/Calendar.js +0 -209
  333. package/packages/ui/react/components/Date/Date.d.ts.map +0 -1
  334. package/packages/ui/react/components/Date/Date.js +0 -160
  335. package/packages/ui/react/components/Date/DateTestPage.d.ts.map +0 -1
  336. package/packages/ui/react/components/Date/DateTestPage.js +0 -32
  337. package/packages/ui/react/components/Date/LocaleContext.d.ts +0 -2
  338. package/packages/ui/react/components/Date/LocaleContext.d.ts.map +0 -1
  339. package/packages/ui/react/components/Date/LocaleContext.js +0 -8
  340. package/packages/ui/react/components/Date/LocaleProvider.d.ts.map +0 -1
  341. package/packages/ui/react/components/Date/LocaleProvider.js +0 -16
  342. package/packages/ui/react/components/Date/TimePicker.d.ts.map +0 -1
  343. package/packages/ui/react/components/Date/TimePicker.js +0 -78
  344. package/packages/ui/react/components/Date/data.d.ts.map +0 -1
  345. package/packages/ui/react/components/Date/data.js +0 -7
  346. package/packages/ui/react/components/Date/dateLocaleStore.d.ts.map +0 -1
  347. package/packages/ui/react/components/Date/dateLocaleStore.js +0 -17
  348. package/packages/ui/react/components/Date/index.d.ts.map +0 -1
  349. package/packages/ui/react/components/Date/index.js +0 -23
  350. package/packages/ui/react/components/Date/locales.d.ts.map +0 -1
  351. package/packages/ui/react/components/Dropdown.d.ts.map +0 -1
  352. package/packages/ui/react/components/Dropdown.js +0 -55
  353. package/packages/ui/react/components/Form/Form.d.ts.map +0 -1
  354. package/packages/ui/react/components/Form/Form.js +0 -14
  355. package/packages/ui/react/components/Form/FormItem.d.ts.map +0 -1
  356. package/packages/ui/react/components/Form/FormItem.js +0 -75
  357. package/packages/ui/react/components/Form/SchemeForm/data.d.ts.map +0 -1
  358. package/packages/ui/react/components/Form/SchemeForm/index.d.ts.map +0 -1
  359. package/packages/ui/react/components/Form/SchemeForm/index.js +0 -69
  360. package/packages/ui/react/components/Form/index.d.ts.map +0 -1
  361. package/packages/ui/react/components/Form/index.js +0 -20
  362. package/packages/ui/react/components/Form/useForm.d.ts.map +0 -1
  363. package/packages/ui/react/components/Form/useForm.js +0 -5
  364. package/packages/ui/react/components/ImagePreview/ImagePreview.d.ts.map +0 -1
  365. package/packages/ui/react/components/ImagePreview/PreviewImage.d.ts.map +0 -1
  366. package/packages/ui/react/components/ImagePreview/PreviewImage.js +0 -28
  367. package/packages/ui/react/components/ImagePreview/index.d.ts.map +0 -1
  368. package/packages/ui/react/components/ImagePreview/index.js +0 -18
  369. package/packages/ui/react/components/Input/Input.d.ts.map +0 -1
  370. package/packages/ui/react/components/Input/Input.js +0 -60
  371. package/packages/ui/react/components/Input/index.d.ts.map +0 -1
  372. package/packages/ui/react/components/Input/index.js +0 -17
  373. package/packages/ui/react/components/Label/Label.d.ts.map +0 -1
  374. package/packages/ui/react/components/Label/Label.js +0 -36
  375. package/packages/ui/react/components/Label/index.d.ts.map +0 -1
  376. package/packages/ui/react/components/Label/index.js +0 -20
  377. package/packages/ui/react/components/Message/Message.d.ts.map +0 -1
  378. package/packages/ui/react/components/Message/Message.js +0 -55
  379. package/packages/ui/react/components/Message/MessageManager.d.ts.map +0 -1
  380. package/packages/ui/react/components/Message/data.d.ts.map +0 -1
  381. package/packages/ui/react/components/Message/data.js +0 -4
  382. package/packages/ui/react/components/Message/index.d.ts.map +0 -1
  383. package/packages/ui/react/components/Message/index.js +0 -5
  384. package/packages/ui/react/components/Modal/Modal.d.ts.map +0 -1
  385. package/packages/ui/react/components/Modal/Modal.js +0 -50
  386. package/packages/ui/react/components/Modal/ModalManager.d.ts.map +0 -1
  387. package/packages/ui/react/components/Modal/index.d.ts.map +0 -1
  388. package/packages/ui/react/components/Modal/index.js +0 -7
  389. package/packages/ui/react/components/Pagination.d.ts.map +0 -1
  390. package/packages/ui/react/components/Search/Search.d.ts.map +0 -1
  391. package/packages/ui/react/components/Search/Search.js +0 -14
  392. package/packages/ui/react/components/Search/index.d.ts.map +0 -1
  393. package/packages/ui/react/components/Search/index.js +0 -8
  394. package/packages/ui/react/components/Select/Select.d.ts.map +0 -1
  395. package/packages/ui/react/components/Select/Select.js +0 -166
  396. package/packages/ui/react/components/Select/index.d.ts.map +0 -1
  397. package/packages/ui/react/components/Select/index.js +0 -17
  398. package/packages/ui/react/components/Skeleton/Skeleton.d.ts.map +0 -1
  399. package/packages/ui/react/components/Skeleton/Skeleton.js +0 -35
  400. package/packages/ui/react/components/Skeleton/index.d.ts.map +0 -1
  401. package/packages/ui/react/components/Skeleton/index.js +0 -5
  402. package/packages/ui/react/components/Switch/Switch.d.ts.map +0 -1
  403. package/packages/ui/react/components/Switch/Switch.js +0 -56
  404. package/packages/ui/react/components/Switch/index.d.ts.map +0 -1
  405. package/packages/ui/react/components/Switch/index.js +0 -17
  406. package/packages/ui/react/components/TableSearch/TableSearch.d.ts.map +0 -1
  407. package/packages/ui/react/components/TableSearch/index.d.ts.map +0 -1
  408. package/packages/ui/react/components/TableSearch/index.js +0 -8
  409. package/packages/ui/react/components/TableSearch/lang.d.ts.map +0 -1
  410. package/packages/ui/react/components/TableSearch/lang.js +0 -27
  411. package/packages/ui/react/components/TableSearch/tableSearchLocaleStore.d.ts.map +0 -1
  412. package/packages/ui/react/components/TableSearch/tableSearchLocaleStore.js +0 -14
  413. package/packages/ui/react/components/Textarea.d.ts.map +0 -1
  414. package/packages/ui/react/components/Textarea.js +0 -37
  415. package/packages/ui/react/components/Tooltip.d.ts.map +0 -1
  416. package/packages/ui/react/components/TreeSelect.d.ts.map +0 -1
  417. package/packages/ui/react/components/Upload/ImageUpload.d.ts.map +0 -1
  418. package/packages/ui/react/components/Upload/Upload.d.ts.map +0 -1
  419. package/packages/ui/react/components/Upload/Upload.js +0 -8
  420. package/packages/ui/react/components/Upload/index.d.ts.map +0 -1
  421. package/packages/ui/react/components/Upload/index.js +0 -18
  422. package/packages/ui/react/components/breadcrumb.d.ts.map +0 -1
  423. package/packages/ui/react/components/breadcrumb.js +0 -79
  424. package/packages/ui/react/components/hooks/useInputController.d.ts.map +0 -1
  425. package/packages/ui/react/components/index.d.ts.map +0 -1
  426. package/packages/ui/react/components/index.js +0 -39
  427. package/packages/ui/react/components/table.d.ts.map +0 -1
  428. package/packages/ui/react/components/table.js +0 -63
  429. package/packages/ui/react/components/testPage/index.d.ts.map +0 -1
  430. package/packages/ui/react/components/testPage/index.js +0 -123
  431. package/packages/ui/react/hooks/useBreadcrumb.d.ts.map +0 -1
  432. package/packages/ui/react/hooks/useBreadcrumb.js +0 -5
  433. package/packages/ui/react/hooks/useInit.d.ts.map +0 -1
  434. package/packages/ui/react/hooks/useInit.js +0 -11
  435. package/packages/ui/react/hooks/useLanguage.d.ts.map +0 -1
  436. package/packages/ui/react/hooks/useLanguage.js +0 -7
  437. package/packages/ui/react/hooks/usePagination.d.ts.map +0 -1
  438. package/packages/ui/react/index.d.ts.map +0 -1
  439. package/packages/ui/react/index.js +0 -18
  440. package/packages/ui/react/lib/export.d.ts +0 -22
  441. package/packages/ui/react/lib/export.d.ts.map +0 -1
  442. package/packages/ui/react/lib/utils.d.ts +0 -10
  443. package/packages/ui/react/lib/utils.d.ts.map +0 -1
  444. package/packages/ui/react/locales/index.d.ts.map +0 -1
  445. package/packages/ui/react/locales/index.js +0 -9
  446. package/packages/ui/react/stores/breadcrumb.d.ts.map +0 -1
  447. package/packages/ui/react/stores/language.d.ts.map +0 -1
  448. package/packages/ui/react/types/index.d.ts.map +0 -1
  449. package/packages/ui/react/types/index.js +0 -2
  450. package/packages/utils/getAllFilesInFolder.d.ts.map +0 -1
  451. package/packages/utils/getAllFnReturnValue.d.ts.map +0 -1
  452. package/packages/utils/getAllFnReturnValue.js +0 -1
  453. package/packages/utils/index.d.ts.map +0 -1
  454. package/packages/utils/loadFile.d.ts.map +0 -1
  455. package/packages/utils/path.d.ts +0 -7
  456. package/packages/utils/path.d.ts.map +0 -1
  457. package/packages/utils/runFileFn.d.ts.map +0 -1
  458. package/typings/type.d.ts +0 -2
  459. package/typings/type.d.ts.map +0 -1
  460. /package/{app → cjs/app}/controller/view.js +0 -0
  461. /package/{app → cjs/app}/data/signKey.js +0 -0
  462. /package/{app → cjs/app}/extend/logger.js +0 -0
  463. /package/{app → cjs/app}/extend/parsingParamsOnUrl.js +0 -0
  464. /package/{app → cjs/app}/extend/render-view.js +0 -0
  465. /package/{app → cjs/app}/middleware/api-params-verify.js +0 -0
  466. /package/{app → cjs/app}/middleware/api-sign-verify.js +0 -0
  467. /package/{app → cjs/app}/middleware/error-handle.js +0 -0
  468. /package/{app → cjs/app}/middleware/project-handler.js +0 -0
  469. /package/{app → cjs/app}/router/project.js +0 -0
  470. /package/{app → cjs/app}/router/view.js +0 -0
  471. /package/{app → cjs/app}/router-schema/project.js +0 -0
  472. /package/{app → cjs/app}/service/bese.js +0 -0
  473. /package/{app → cjs/app}/type.js +0 -0
  474. /package/{app → cjs/app}/typings.js +0 -0
  475. /package/{index.js → cjs/index.js} +0 -0
  476. /package/{packages → cjs/packages}/core/env.js +0 -0
  477. /package/{packages → cjs/packages}/core/paths.js +0 -0
  478. /package/{packages → cjs/packages}/core/types.js +0 -0
  479. /package/{packages → cjs/packages}/utils/getAllFilesInFolder.js +0 -0
  480. /package/{packages → cjs/packages}/utils/index.js +0 -0
  481. /package/{packages → cjs/packages}/utils/runFileFn.js +0 -0
  482. /package/{typings → cjs/typings}/type.js +0 -0
  483. /package/{app → esm/app}/data/signKey.d.ts +0 -0
  484. /package/{app → esm/app}/extend/db.d.ts +0 -0
  485. /package/{app → esm/app}/extend/generateErrorMessage.d.ts +0 -0
  486. /package/{app → esm/app}/extend/logger.d.ts +0 -0
  487. /package/{app → esm/app}/extend/parsingParamsOnUrl.d.ts +0 -0
  488. /package/{app → esm/app}/middleware.d.ts +0 -0
  489. /package/{app → esm/app}/router/project.d.ts +0 -0
  490. /package/{app → esm/app}/router/view.d.ts +0 -0
  491. /package/{app → esm/app}/router-schema/project.d.ts +0 -0
  492. /package/{app → esm/app}/service/bese.d.ts +0 -0
  493. /package/{app → esm/app}/service/project.d.ts +0 -0
  494. /package/{app → esm/app}/type.d.ts +0 -0
  495. /package/{app → esm/app}/typings.d.ts +0 -0
  496. /package/{index.d.ts → esm/index.d.ts} +0 -0
  497. /package/{packages → esm/packages}/core/env.d.ts +0 -0
  498. /package/{packages → esm/packages}/core/index.d.ts +0 -0
  499. /package/{packages → esm/packages}/core/paths.d.ts +0 -0
  500. /package/{packages → esm/packages}/utils/getAllFnReturnValue.d.ts +0 -0
  501. /package/{packages → esm/packages}/utils/index.d.ts +0 -0
  502. /package/{packages → esm/packages}/utils/runFileFn.d.ts +0 -0
  503. /package/{app/pages → fe/frontend}/main.d.ts +0 -0
  504. /package/{packages → fe/packages}/ui/react/components/Button/index.d.ts +0 -0
  505. /package/{packages → fe/packages}/ui/react/components/Checkbox/Checkbox.d.ts +0 -0
  506. /package/{packages → fe/packages}/ui/react/components/Checkbox/index.d.ts +0 -0
  507. /package/{packages → fe/packages}/ui/react/components/DataTable/ActionBtn.d.ts +0 -0
  508. /package/{packages → fe/packages}/ui/react/components/Date/DateTestPage.d.ts +0 -0
  509. /package/{packages → fe/packages}/ui/react/components/Date/TimePicker.d.ts +0 -0
  510. /package/{packages → fe/packages}/ui/react/components/Date/data.d.ts +0 -0
  511. /package/{packages → fe/packages}/ui/react/components/Date/index.d.ts +0 -0
  512. /package/{packages → fe/packages}/ui/react/components/Dropdown.d.ts +0 -0
  513. /package/{packages → fe/packages}/ui/react/components/Form/SchemeForm/data.d.ts +0 -0
  514. /package/{packages → fe/packages}/ui/react/components/Form/index.d.ts +0 -0
  515. /package/{packages → fe/packages}/ui/react/components/Form/useForm.d.ts +0 -0
  516. /package/{packages → fe/packages}/ui/react/components/ImagePreview/ImagePreview.d.ts +0 -0
  517. /package/{packages → fe/packages}/ui/react/components/ImagePreview/index.d.ts +0 -0
  518. /package/{packages → fe/packages}/ui/react/components/Input/index.d.ts +0 -0
  519. /package/{packages → fe/packages}/ui/react/components/Label/index.d.ts +0 -0
  520. /package/{packages → fe/packages}/ui/react/components/Message/MessageManager.d.ts +0 -0
  521. /package/{packages → fe/packages}/ui/react/components/Message/data.d.ts +0 -0
  522. /package/{packages → fe/packages}/ui/react/components/Message/index.d.ts +0 -0
  523. /package/{packages → fe/packages}/ui/react/components/Modal/index.d.ts +0 -0
  524. /package/{packages → fe/packages}/ui/react/components/Search/index.d.ts +0 -0
  525. /package/{packages → fe/packages}/ui/react/components/Select/index.d.ts +0 -0
  526. /package/{packages → fe/packages}/ui/react/components/Skeleton/index.d.ts +0 -0
  527. /package/{packages → fe/packages}/ui/react/components/Switch/Switch.d.ts +0 -0
  528. /package/{packages → fe/packages}/ui/react/components/Switch/index.d.ts +0 -0
  529. /package/{packages → fe/packages}/ui/react/components/TableSearch/index.d.ts +0 -0
  530. /package/{packages → fe/packages}/ui/react/components/TableSearch/lang.d.ts +0 -0
  531. /package/{packages → fe/packages}/ui/react/components/TableSearch/tableSearchLocaleStore.d.ts +0 -0
  532. /package/{packages → fe/packages}/ui/react/components/Upload/ImageUpload.d.ts +0 -0
  533. /package/{packages → fe/packages}/ui/react/components/Upload/index.d.ts +0 -0
  534. /package/{packages → fe/packages}/ui/react/components/breadcrumb.d.ts +0 -0
  535. /package/{packages → fe/packages}/ui/react/components/index.d.ts +0 -0
  536. /package/{packages → fe/packages}/ui/react/components/table.d.ts +0 -0
  537. /package/{packages → fe/packages}/ui/react/components/testPage/index.d.ts +0 -0
  538. /package/{packages → fe/packages}/ui/react/hooks/useBreadcrumb.d.ts +0 -0
  539. /package/{packages → fe/packages}/ui/react/hooks/useInit.d.ts +0 -0
  540. /package/{packages → fe/packages}/ui/react/hooks/useLanguage.d.ts +0 -0
  541. /package/{packages → fe/packages}/ui/react/hooks/usePagination.d.ts +0 -0
  542. /package/{packages → fe/packages}/ui/react/index.d.ts +0 -0
  543. /package/{packages → fe/packages}/ui/react/locales/index.d.ts +0 -0
  544. /package/{packages → fe/packages}/ui/react/stores/breadcrumb.d.ts +0 -0
  545. /package/{packages → fe/packages}/ui/react/stores/language.d.ts +0 -0
  546. /package/{packages → fe/packages}/ui/react/types/index.d.ts +0 -0
@@ -0,0 +1,178 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn } from '../../lib/utils';
3
+ import { format as formatDate, isValid, parse } from 'date-fns';
4
+ import { Calendar as CalendarIcon, X } from 'lucide-react';
5
+ import { forwardRef, useEffect, useMemo, useRef, useState } from 'react';
6
+ import { Calendar } from './Calendar';
7
+ import { ModeType } from './data';
8
+ import { useDateLocale } from './LocaleContext';
9
+ const formatValue = (val, format) => {
10
+ if (!val)
11
+ return '';
12
+ if (val instanceof Date)
13
+ return formatDate(val, format);
14
+ if ('from' in val) {
15
+ if (val.from && val.to) {
16
+ return `${formatDate(val.from, format)} - ${formatDate(val.to, format)}`;
17
+ }
18
+ if (val.from) {
19
+ return formatDate(val.from, format);
20
+ }
21
+ }
22
+ return '';
23
+ };
24
+ const formatDateValue = (val, format) => {
25
+ if (!val)
26
+ return '';
27
+ /**
28
+ * 将 DateBaseValue 转为 yyyy-MM-dd | [yyyy-MM-dd, yyyy-MM-dd]
29
+ */
30
+ if (val instanceof Date)
31
+ return formatDate(val, format);
32
+ if ('from' in val) {
33
+ if (val.from && val.to) {
34
+ return [formatDate(val.from, format), formatDate(val.to, format)];
35
+ }
36
+ }
37
+ return '';
38
+ };
39
+ const DatePicker = forwardRef(({ mode = ModeType.Single, className, format: customFormat, placeholder, allowClear = true, disabled = false, showTime = false, value: pValue, defaultValue: pDefaultValue, onChange, disabledDate, locale: customLocale, quickRanges, }, ref) => {
40
+ const contextLocale = useDateLocale();
41
+ const locale = { ...contextLocale, ...customLocale };
42
+ // 如果没有传入 placeholder,根据模式自动选择
43
+ const finalPlaceholder = placeholder ||
44
+ (showTime
45
+ ? mode === ModeType.Range
46
+ ? locale.placeholderDateTimeRange
47
+ : locale.placeholderDateTime
48
+ : mode === ModeType.Range
49
+ ? locale.placeholderRange
50
+ : locale.placeholder);
51
+ // Auto-adjust format based on showTime
52
+ const format = customFormat || (showTime ? 'yyyy-MM-dd HH:mm' : 'yyyy-MM-dd');
53
+ const { value, defaultValue } = useMemo(() => {
54
+ /**
55
+ * 将 DateChangeStrValue 转为 Dates
56
+ */
57
+ const convertValue = (val) => {
58
+ if (!val)
59
+ return undefined;
60
+ // Already a Date object
61
+ if (val instanceof Date)
62
+ return val;
63
+ // Already a DateRange object
64
+ if (typeof val === 'object' && 'from' in val)
65
+ return val;
66
+ // String value - single date
67
+ if (typeof val === 'string') {
68
+ try {
69
+ const parsed = parse(val, format, new Date());
70
+ return isValid(parsed) ? parsed : undefined;
71
+ }
72
+ catch {
73
+ return undefined;
74
+ }
75
+ }
76
+ // date range
77
+ if (Array.isArray(val)) {
78
+ // string
79
+ if (typeof val[0] === 'string' && typeof val[1] === 'string') {
80
+ try {
81
+ const from = parse(val[0], format, new Date());
82
+ const to = parse(val[1], format, new Date());
83
+ return isValid(from) && isValid(to) ? { from, to } : undefined;
84
+ }
85
+ catch {
86
+ return undefined;
87
+ }
88
+ }
89
+ else {
90
+ return { from: val[0], to: val[1] };
91
+ }
92
+ }
93
+ return undefined;
94
+ };
95
+ return {
96
+ value: convertValue(pValue),
97
+ defaultValue: convertValue(pDefaultValue),
98
+ };
99
+ }, [pDefaultValue, pValue, format]);
100
+ const [selectedDate, setSelectedDate] = useState(value || defaultValue);
101
+ const [isOpen, setIsOpen] = useState(false);
102
+ const [inputValue, setInputValue] = useState(formatValue(value || defaultValue, format));
103
+ const [isHover, setIsHover] = useState(false);
104
+ const containerRef = useRef(null);
105
+ const inputRef = useRef(null);
106
+ // 同步外部 value 变化
107
+ useEffect(() => {
108
+ if (value !== undefined) {
109
+ // eslint-disable-next-line react-hooks/set-state-in-effect
110
+ setSelectedDate(value);
111
+ setInputValue(formatValue(value, format));
112
+ }
113
+ }, [value, format]);
114
+ // 点击外部关闭
115
+ useEffect(() => {
116
+ const handleClickOutside = (event) => {
117
+ if (containerRef.current && !containerRef.current.contains(event.target)) {
118
+ setIsOpen(false);
119
+ }
120
+ };
121
+ if (isOpen) {
122
+ document.addEventListener('mousedown', handleClickOutside);
123
+ return () => document.removeEventListener('mousedown', handleClickOutside);
124
+ }
125
+ else {
126
+ return () => { };
127
+ }
128
+ }, [isOpen]);
129
+ const handleSelect = (date) => {
130
+ const newDate = date;
131
+ if (mode === ModeType.Range) {
132
+ // 如果是范围选择,只有当 from 和 to 都存在时才关闭
133
+ if (date && 'from' in date && 'to' in date && date.from && date.to) {
134
+ setIsOpen(false);
135
+ }
136
+ }
137
+ else {
138
+ // Single mode: always close popup when onChange is triggered
139
+ // (In showTime mode, this only happens when user clicks confirm button)
140
+ setIsOpen(false);
141
+ }
142
+ setSelectedDate(newDate);
143
+ setInputValue(formatValue(newDate, format));
144
+ // 只在非受控模式下更新内部状态
145
+ if (value === undefined) {
146
+ setSelectedDate(newDate);
147
+ }
148
+ onChange?.(formatDateValue(newDate, format), newDate);
149
+ };
150
+ const handleClear = (e) => {
151
+ e.stopPropagation();
152
+ setSelectedDate(undefined);
153
+ setInputValue('');
154
+ onChange?.(undefined, undefined);
155
+ inputRef.current?.focus();
156
+ };
157
+ const handleInputChange = (e) => {
158
+ const newValue = e.target.value;
159
+ setInputValue(newValue);
160
+ if (mode === ModeType.Single) {
161
+ try {
162
+ const parsedDate = parse(newValue, format, new Date());
163
+ if (isValid(parsedDate)) {
164
+ if (value === undefined)
165
+ setSelectedDate(parsedDate);
166
+ onChange?.(formatDateValue(parsedDate, format), parsedDate);
167
+ }
168
+ }
169
+ catch {
170
+ // ignore invalid date
171
+ }
172
+ }
173
+ };
174
+ const showClearIcon = allowClear && selectedDate && !disabled && isHover;
175
+ return (_jsx("div", { ref: ref, className: cn('relative w-full', mode === ModeType.Range ? 'min-w-[255px]' : '', className), children: _jsxs("div", { ref: containerRef, className: "relative", children: [_jsxs("div", { className: cn('flex items-center w-full rounded-lg px-4 py-3 text-sm', 'border transition-colors duration-200', 'bg-background cursor-pointer', disabled && 'cursor-not-allowed bg-muted border-border text-muted-foreground', !disabled && !selectedDate && !isOpen && 'border-border', !disabled && (selectedDate || isOpen) && 'border-theme'), onClick: () => !disabled && setIsOpen(!isOpen), onMouseEnter: () => setIsHover(true), onMouseLeave: () => setIsHover(false), children: [_jsx("input", { ref: inputRef, type: "text", value: inputValue, onChange: handleInputChange, placeholder: finalPlaceholder, disabled: disabled, readOnly: mode === ModeType.Range, className: cn('flex-1 bg-transparent border-0 outline-none', 'text-sm text-foreground placeholder:text-muted-foreground', disabled && 'cursor-not-allowed', mode === ModeType.Range && !disabled && 'cursor-pointer caret-transparent') }), showClearIcon ? (_jsx("button", { type: "button", onClick: handleClear, title: locale.clear, "aria-label": locale.clear, className: cn('ml-2 flex items-center justify-center', 'w-5 h-5 rounded-full', 'bg-muted hover:bg-muted/80', 'text-foreground transition-colors'), children: _jsx(X, { size: 12 }) })) : (_jsx(CalendarIcon, { size: 16, className: "ml-2 text-muted-foreground" }))] }), isOpen && !disabled && (_jsx("div", { className: cn('absolute z-50 mt-2', 'bg-background border border-border rounded-lg shadow-lg', 'overflow-hidden'), children: _jsx(Calendar, { mode: mode, value: selectedDate || null, onChange: handleSelect, disabledDate: disabledDate, showTime: showTime, locale: locale, quickRanges: quickRanges }) }))] }) }));
176
+ });
177
+ DatePicker.displayName = 'DatePicker';
178
+ export { DatePicker };
@@ -0,0 +1,29 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { startOfDay } from 'date-fns';
3
+ import { useState } from 'react';
4
+ import { DatePicker } from './Date';
5
+ export default function DateTestPage() {
6
+ const [date1, setDate1] = useState();
7
+ const [dateTime1, setDateTime1] = useState();
8
+ const [range, setRange] = useState();
9
+ const [rangeWithTime, setRangeWithTime] = useState();
10
+ const [emptyRange, setEmptyRange] = useState();
11
+ return (_jsxs("div", { className: "p-8 max-w-6xl mx-auto space-y-8", children: [_jsxs("div", { children: [_jsx("h1", { className: "text-3xl font-bold mb-2", children: "Date \u7EC4\u4EF6\u4F7F\u7528\u793A\u4F8B" }), _jsx("p", { className: "text-muted-foreground", children: "\u5C55\u793A DatePicker \u7EC4\u4EF6\u7684\u5404\u79CD\u4F7F\u7528\u573A\u666F" })] }), _jsxs("section", { className: "space-y-4", children: [_jsx("h2", { className: "text-xl font-semibold", children: "1. \u57FA\u672C\u7528\u6CD5" }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { children: [_jsx("p", { className: "text-sm text-muted-foreground mb-2", children: "\u5355\u65E5\u671F\u9009\u62E9" }), _jsx(DatePicker, { placeholder: "\u8BF7\u9009\u62E9\u65E5\u671F" })] }), _jsxs("div", { children: [_jsx("p", { className: "text-sm text-muted-foreground mb-2", children: "\u7981\u7528\u6E05\u9664\u6309\u94AE" }), _jsx(DatePicker, { placeholder: "\u8BF7\u9009\u62E9\u65E5\u671F", allowClear: false })] })] })] }), _jsxs("section", { className: "space-y-4", children: [_jsx("h2", { className: "text-xl font-semibold", children: "2. \u65E5\u671F\u65F6\u95F4\u9009\u62E9\u5668 (showTime)" }), _jsx("p", { className: "text-sm text-muted-foreground", children: "\u65F6\u95F4\u9009\u62E9\u5668\u663E\u793A\u5728\u65E5\u5386\u53F3\u4FA7\uFF0C\u63D0\u4F9B\u66F4\u597D\u7684\u7528\u6237\u4F53\u9A8C" }), _jsxs("div", { className: "grid grid-cols-2 gap-8", children: [_jsxs("div", { children: [_jsx("h3", { className: "text-sm font-medium mb-2", children: "\u57FA\u672C\u7528\u6CD5 - \u5355\u65E5\u671F\u65F6\u95F4" }), _jsx(DatePicker, { showTime: true, placeholder: "\u8BF7\u9009\u62E9\u65E5\u671F\u65F6\u95F4" }), _jsx("p", { className: "text-xs text-muted-foreground mt-2", children: "\u70B9\u51FB\u8F93\u5165\u6846\u6253\u5F00\u9009\u62E9\u5668\uFF0C\u65F6\u95F4\u9009\u62E9\u5668\u5728\u53F3\u4FA7\u663E\u793A" })] }), _jsxs("div", { children: [_jsx("h3", { className: "text-sm font-medium mb-2", children: "\u53D7\u63A7\u6A21\u5F0F" }), _jsx(DatePicker, { showTime: true, value: dateTime1, onChange: (val, date) => {
12
+ setDateTime1(val);
13
+ console.log('选中日期时间:', val);
14
+ console.log('Date 对象:', date);
15
+ }, placeholder: "\u53D7\u63A7\u65E5\u671F\u65F6\u95F4\u9009\u62E9\u5668" }), _jsxs("p", { className: "text-sm text-muted-foreground mt-2", children: ["\u9009\u4E2D\u7684\u503C: ", _jsx("code", { className: "text-xs bg-muted px-1 py-0.5 rounded", children: String(dateTime1 || '未选择') })] })] })] })] }), _jsxs("section", { className: "space-y-4", children: [_jsx("h2", { className: "text-xl font-semibold", children: "3. \u8303\u56F4\u9009\u62E9 (Range Picker)" }), _jsxs("div", { className: "grid grid-cols-2 gap-8", children: [_jsxs("div", { children: [_jsx("h3", { className: "text-sm font-medium mb-2", children: "\u57FA\u672C\u8303\u56F4\u9009\u62E9" }), _jsx(DatePicker, { mode: "range", value: emptyRange, onChange: (val) => {
16
+ setEmptyRange(val);
17
+ console.log('范围选择:', val);
18
+ }, placeholder: "\u9009\u62E9\u65E5\u671F\u8303\u56F4" }), _jsxs("p", { className: "text-sm text-muted-foreground mt-2", children: ["\u503C: ", _jsx("code", { className: "text-xs bg-muted px-1 py-0.5 rounded", children: JSON.stringify(emptyRange || '未选择') })] })] }), _jsxs("div", { children: [_jsx("h3", { className: "text-sm font-medium mb-2", children: "\u8303\u56F4\u9009\u62E9 + \u65F6\u95F4\u9009\u62E9" }), _jsx(DatePicker, { mode: "range", value: rangeWithTime, showTime: true, onChange: (val) => {
19
+ setRangeWithTime(val);
20
+ console.log('范围时间选择:', val);
21
+ }, placeholder: "\u9009\u62E9\u65E5\u671F\u65F6\u95F4\u8303\u56F4" }), _jsxs("p", { className: "text-sm text-muted-foreground mt-2", children: ["\u503C:", ' ', _jsx("code", { className: "text-xs bg-muted px-1 py-0.5 rounded", children: JSON.stringify(rangeWithTime || '未选择') })] }), _jsx("p", { className: "text-xs text-muted-foreground mt-1", children: "\u9009\u62E9\u5F00\u59CB\u65E5\u671F\u540E\uFF0C\u53F3\u4FA7\u4F1A\u663E\u793A\u5F00\u59CB\u65F6\u95F4\u9009\u62E9\u5668\uFF1B\u9009\u62E9\u7ED3\u675F\u65E5\u671F\u540E\uFF0C\u4F1A\u663E\u793A\u7ED3\u675F\u65F6\u95F4\u9009\u62E9\u5668" })] })] })] }), _jsxs("section", { className: "space-y-4", children: [_jsx("h2", { className: "text-xl font-semibold", children: "4. \u53D7\u63A7\u6A21\u5F0F" }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { children: [_jsx("p", { className: "text-sm text-muted-foreground mb-2", children: "\u5355\u65E5\u671F\u53D7\u63A7" }), _jsx(DatePicker, { value: date1, onChange: (date, dateString) => {
22
+ setDate1(date);
23
+ console.log('选中日期:', date);
24
+ console.log('日期字符串:', dateString);
25
+ }, placeholder: "\u53D7\u63A7\u65E5\u671F\u9009\u62E9\u5668" }), _jsxs("p", { className: "text-sm text-muted-foreground mt-2", children: ["\u9009\u4E2D\u7684\u65E5\u671F: ", _jsx("code", { className: "text-xs bg-muted px-1 py-0.5 rounded", children: String(date1 || '未选择') })] })] }), _jsxs("div", { children: [_jsx("p", { className: "text-sm text-muted-foreground mb-2", children: "\u8303\u56F4\u53D7\u63A7" }), _jsx(DatePicker, { mode: "range", value: range, onChange: (val) => {
26
+ setRange(val);
27
+ console.log('范围变化:', val);
28
+ }, placeholder: "\u53D7\u63A7\u8303\u56F4\u9009\u62E9\u5668" }), _jsxs("p", { className: "text-sm text-muted-foreground mt-2", children: ["\u503C: ", _jsx("code", { className: "text-xs bg-muted px-1 py-0.5 rounded", children: JSON.stringify(range || '未选择') })] })] })] })] }), _jsxs("section", { className: "space-y-4", children: [_jsx("h2", { className: "text-xl font-semibold", children: "5. \u7981\u7528\u65E5\u671F" }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { children: [_jsx("p", { className: "text-sm text-muted-foreground mb-2", children: "\u53EA\u80FD\u9009\u62E9\u4ECA\u5929\u53CA\u4EE5\u540E" }), _jsx(DatePicker, { disabledDate: (current) => current < startOfDay(new Date()), placeholder: "\u9009\u62E9\u672A\u6765\u65E5\u671F" })] }), _jsxs("div", { children: [_jsx("p", { className: "text-sm text-muted-foreground mb-2", children: "\u8303\u56F4\u9009\u62E9\uFF08\u7981\u7528\u8FC7\u53BB\uFF09" }), _jsx(DatePicker, { mode: "range", disabledDate: (current) => current < startOfDay(new Date()), placeholder: "\u9009\u62E9\u672A\u6765\u8303\u56F4" })] })] })] }), _jsxs("section", { className: "space-y-4", children: [_jsx("h2", { className: "text-xl font-semibold", children: "6. \u7981\u7528\u72B6\u6001" }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { children: [_jsx("p", { className: "text-sm text-muted-foreground mb-2", children: "\u7981\u7528\u72B6\u6001" }), _jsx(DatePicker, { disabled: true, placeholder: "\u7981\u7528\u72B6\u6001" })] }), _jsxs("div", { children: [_jsx("p", { className: "text-sm text-muted-foreground mb-2", children: "\u7981\u7528\u72B6\u6001 + \u6709\u503C" }), _jsx(DatePicker, { disabled: true, value: "2024-01-15", placeholder: "\u7981\u7528\u72B6\u6001" })] })] })] }), _jsxs("section", { className: "space-y-4", children: [_jsx("h2", { className: "text-xl font-semibold", children: "7. \u81EA\u5B9A\u4E49\u683C\u5F0F" }), _jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsxs("div", { children: [_jsx("p", { className: "text-sm text-muted-foreground mb-2", children: "\u81EA\u5B9A\u4E49\u65E5\u671F\u683C\u5F0F" }), _jsx(DatePicker, { format: "yyyy/MM/dd", placeholder: "\u9009\u62E9\u65E5\u671F (yyyy/MM/dd)" })] }), _jsxs("div", { children: [_jsx("p", { className: "text-sm text-muted-foreground mb-2", children: "\u81EA\u5B9A\u4E49\u65E5\u671F\u65F6\u95F4\u683C\u5F0F" }), _jsx(DatePicker, { showTime: true, format: "yyyy-MM-dd HH:mm:ss", placeholder: "\u9009\u62E9\u65E5\u671F\u65F6\u95F4 (yyyy-MM-dd HH:mm:ss)" })] })] })] }), _jsxs("section", { className: "space-y-4 border-t pt-6", children: [_jsx("h2", { className: "text-xl font-semibold", children: "API \u8BF4\u660E" }), _jsxs("div", { className: "bg-muted/50 p-4 rounded-lg space-y-2 text-sm", children: [_jsxs("div", { children: [_jsx("code", { className: "font-semibold", children: "showTime" }), _jsx("span", { className: "text-muted-foreground ml-2", children: ": boolean - \u662F\u5426\u663E\u793A\u65F6\u95F4\u9009\u62E9\u5668\uFF0C\u65F6\u95F4\u9009\u62E9\u5668\u4F1A\u663E\u793A\u5728\u65E5\u5386\u53F3\u4FA7" })] }), _jsxs("div", { children: [_jsx("code", { className: "font-semibold", children: "mode" }), _jsx("span", { className: "text-muted-foreground ml-2", children: ": 'single' | 'range' - \u9009\u62E9\u6A21\u5F0F\uFF0Csingle \u4E3A\u5355\u65E5\u671F\uFF0Crange \u4E3A\u65E5\u671F\u8303\u56F4" })] }), _jsxs("div", { children: [_jsx("code", { className: "font-semibold", children: "value" }), _jsx("span", { className: "text-muted-foreground ml-2", children: ": string | [string, string] - \u53D7\u63A7\u6A21\u5F0F\u7684\u503C" })] }), _jsxs("div", { children: [_jsx("code", { className: "font-semibold", children: "onChange" }), _jsxs("span", { className: "text-muted-foreground ml-2", children: [": (value?: DateChangeStrValue, date?: Date | DateRange) =", '>', " void - \u503C\u53D8\u5316\u56DE\u8C03"] })] }), _jsxs("div", { children: [_jsx("code", { className: "font-semibold", children: "format" }), _jsx("span", { className: "text-muted-foreground ml-2", children: ": string - \u65E5\u671F\u683C\u5F0F\uFF0C\u9ED8\u8BA4 'yyyy-MM-dd'\uFF0CshowTime \u65F6\u4E3A 'yyyy-MM-dd HH:mm'" })] }), _jsxs("div", { children: [_jsx("code", { className: "font-semibold", children: "disabledDate" }), _jsxs("span", { className: "text-muted-foreground ml-2", children: [": (current: Date) =", '>', " boolean - \u7981\u7528\u65E5\u671F\u7684\u5224\u65AD\u51FD\u6570"] })] })] })] })] }));
29
+ }
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Hook for accessing the current Date component locale.
3
+ * Backed by Zustand, so no React Context is required.
4
+ */
5
+ export declare const useDateLocale: () => import("./locales").DateLocaleConfig;
6
+ //# sourceMappingURL=LocaleContext.d.ts.map
@@ -0,0 +1,8 @@
1
+ import { useDateLocaleStore } from './dateLocaleStore';
2
+ /**
3
+ * Hook for accessing the current Date component locale.
4
+ * Backed by Zustand, so no React Context is required.
5
+ */
6
+ export const useDateLocale = () => {
7
+ return useDateLocaleStore((state) => state.locale);
8
+ };
@@ -4,5 +4,16 @@ export interface DateLocaleProviderProps {
4
4
  locale?: DateLocaleConfig;
5
5
  children: ReactNode;
6
6
  }
7
+ /**
8
+ * Date 组件文案配置 Provider
9
+ * 用于全局设置 Date 组件的文案
10
+ *
11
+ * @example
12
+ * ```tsx
13
+ * <DateLocaleProvider locale={customLocale}>
14
+ * <App />
15
+ * </DateLocaleProvider>
16
+ * ```
17
+ */
7
18
  export declare function DateLocaleProvider({ locale, children }: DateLocaleProviderProps): import("react/jsx-runtime").JSX.Element;
8
19
  //# sourceMappingURL=LocaleProvider.d.ts.map
@@ -0,0 +1,24 @@
1
+ import { Fragment as _Fragment, jsx as _jsx } from "react/jsx-runtime";
2
+ import { useEffect } from 'react';
3
+ import { useDateLocaleStore } from './dateLocaleStore';
4
+ import { defaultLocale } from './locales';
5
+ /**
6
+ * Date 组件文案配置 Provider
7
+ * 用于全局设置 Date 组件的文案
8
+ *
9
+ * @example
10
+ * ```tsx
11
+ * <DateLocaleProvider locale={customLocale}>
12
+ * <App />
13
+ * </DateLocaleProvider>
14
+ * ```
15
+ */
16
+ export function DateLocaleProvider({ locale = defaultLocale, children }) {
17
+ const replaceLocale = useDateLocaleStore((state) => state.replaceLocale);
18
+ const resetLocale = useDateLocaleStore((state) => state.resetLocale);
19
+ useEffect(() => {
20
+ replaceLocale(locale);
21
+ return () => resetLocale();
22
+ }, [locale, replaceLocale, resetLocale]);
23
+ return _jsx(_Fragment, { children: children });
24
+ }
@@ -0,0 +1,76 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn } from '../../lib/utils';
3
+ import { ChevronDown, ChevronUp } from 'lucide-react';
4
+ export function TimePicker({ value, onChange, className }) {
5
+ // Derive time from value prop directly
6
+ const hours = value?.getHours() ?? 0;
7
+ const minutes = value?.getMinutes() ?? 0;
8
+ const handleTimeChange = (newHours, newMinutes) => {
9
+ const newDate = value ? new Date(value) : new Date();
10
+ newDate.setHours(newHours);
11
+ newDate.setMinutes(newMinutes);
12
+ newDate.setSeconds(0);
13
+ newDate.setMilliseconds(0);
14
+ onChange?.(newDate);
15
+ };
16
+ const incrementHours = () => {
17
+ const newHours = (hours + 1) % 24;
18
+ handleTimeChange(newHours, minutes);
19
+ };
20
+ const decrementHours = () => {
21
+ const newHours = (hours - 1 + 24) % 24;
22
+ handleTimeChange(newHours, minutes);
23
+ };
24
+ const incrementMinutes = () => {
25
+ const newMinutes = (minutes + 1) % 60;
26
+ handleTimeChange(hours, newMinutes);
27
+ };
28
+ const decrementMinutes = () => {
29
+ const newMinutes = (minutes - 1 + 60) % 60;
30
+ handleTimeChange(hours, newMinutes);
31
+ };
32
+ const handleHoursInput = (e) => {
33
+ const val = e.target.value.replace(/\D/g, '');
34
+ if (val === '') {
35
+ handleTimeChange(0, minutes);
36
+ return;
37
+ }
38
+ const num = parseInt(val, 10);
39
+ if (num >= 0 && num <= 23) {
40
+ handleTimeChange(num, minutes);
41
+ }
42
+ };
43
+ const handleMinutesInput = (e) => {
44
+ const val = e.target.value.replace(/\D/g, '');
45
+ if (val === '') {
46
+ handleTimeChange(hours, 0);
47
+ return;
48
+ }
49
+ const num = parseInt(val, 10);
50
+ if (num >= 0 && num <= 59) {
51
+ handleTimeChange(hours, num);
52
+ }
53
+ };
54
+ const handleHoursKeyDown = (e) => {
55
+ if (e.key === 'ArrowUp') {
56
+ e.preventDefault();
57
+ incrementHours();
58
+ }
59
+ else if (e.key === 'ArrowDown') {
60
+ e.preventDefault();
61
+ decrementHours();
62
+ }
63
+ };
64
+ const handleMinutesKeyDown = (e) => {
65
+ if (e.key === 'ArrowUp') {
66
+ e.preventDefault();
67
+ incrementMinutes();
68
+ }
69
+ else if (e.key === 'ArrowDown') {
70
+ e.preventDefault();
71
+ decrementMinutes();
72
+ }
73
+ };
74
+ const formatNumber = (num) => String(num).padStart(2, '0');
75
+ return (_jsxs("div", { className: cn('flex items-center justify-center gap-3 py-3', className), children: [_jsxs("div", { className: "flex flex-col items-center gap-1", children: [_jsx("button", { type: "button", onClick: incrementHours, className: "p-1 hover:bg-muted rounded transition-colors text-muted-foreground hover:text-foreground", children: _jsx(ChevronUp, { size: 14 }) }), _jsx("input", { type: "text", value: formatNumber(hours), onChange: handleHoursInput, onKeyDown: handleHoursKeyDown, className: cn('w-12 h-9 text-center text-sm font-medium', 'border border-border rounded', 'bg-background text-foreground', 'focus:outline-none focus:border-theme', 'transition-colors'), maxLength: 2 }), _jsx("button", { type: "button", onClick: decrementHours, className: "p-1 hover:bg-muted rounded transition-colors text-muted-foreground hover:text-foreground", children: _jsx(ChevronDown, { size: 14 }) })] }), _jsx("div", { className: "text-lg font-medium text-foreground mb-1", children: ":" }), _jsxs("div", { className: "flex flex-col items-center gap-1", children: [_jsx("button", { type: "button", onClick: incrementMinutes, className: "p-1 hover:bg-muted rounded transition-colors text-muted-foreground hover:text-foreground", children: _jsx(ChevronUp, { size: 14 }) }), _jsx("input", { type: "text", value: formatNumber(minutes), onChange: handleMinutesInput, onKeyDown: handleMinutesKeyDown, className: cn('w-12 h-9 text-center text-sm font-medium', 'border border-border rounded', 'bg-background text-foreground', 'focus:outline-none focus:border-theme', 'transition-colors'), maxLength: 2 }), _jsx("button", { type: "button", onClick: decrementMinutes, className: "p-1 hover:bg-muted rounded transition-colors text-muted-foreground hover:text-foreground", children: _jsx(ChevronDown, { size: 14 }) })] })] }));
76
+ }
@@ -0,0 +1,4 @@
1
+ export const ModeType = {
2
+ Single: 'single',
3
+ Range: 'range',
4
+ };
@@ -1,7 +1,13 @@
1
1
  import { type DateLocaleConfig } from './locales';
2
2
  type DateLocaleState = {
3
3
  locale: DateLocaleConfig;
4
+ /**
5
+ * Merge partial updates into the current locale.
6
+ */
4
7
  setLocale: (patch: Partial<DateLocaleConfig>) => void;
8
+ /**
9
+ * Replace the locale entirely.
10
+ */
5
11
  replaceLocale: (nextLocale: DateLocaleConfig) => void;
6
12
  resetLocale: () => void;
7
13
  };
@@ -0,0 +1,14 @@
1
+ import { create } from 'zustand';
2
+ import { defaultLocale } from './locales';
3
+ export const useDateLocaleStore = create((set) => ({
4
+ locale: defaultLocale,
5
+ setLocale: (patch) => set((state) => ({
6
+ locale: { ...state.locale, ...patch },
7
+ })),
8
+ replaceLocale: (nextLocale) => set(() => ({
9
+ locale: nextLocale,
10
+ })),
11
+ resetLocale: () => set(() => ({
12
+ locale: defaultLocale,
13
+ })),
14
+ }));
@@ -0,0 +1,5 @@
1
+ export * from './Date';
2
+ export * from './dateLocaleStore';
3
+ export { useDateLocale } from './LocaleContext';
4
+ export * from './LocaleProvider';
5
+ export * from './locales';
@@ -1,3 +1,7 @@
1
+ /**
2
+ * Date 组件文案配置
3
+ * 支持外部修改文案内容
4
+ */
1
5
  export interface DateLocaleConfig {
2
6
  placeholder: string;
3
7
  placeholderDateTime: string;
@@ -8,7 +12,13 @@ export interface DateLocaleConfig {
8
12
  startTime: string;
9
13
  endTime: string;
10
14
  confirm: string;
15
+ /**
16
+ * 范围模式 - 快捷选择面板标题
17
+ */
11
18
  quickRanges: string;
19
+ /**
20
+ * 范围模式 - 各快捷范围文案
21
+ */
12
22
  quickRangeToday: string;
13
23
  quickRangeYesterday: string;
14
24
  quickRangeLast7Days: string;
@@ -17,7 +27,16 @@ export interface DateLocaleConfig {
17
27
  quickRangeLastYear: string;
18
28
  clear: string;
19
29
  }
30
+ /**
31
+ * 默认中文文案
32
+ */
20
33
  export declare const zhCNLocale: DateLocaleConfig;
34
+ /**
35
+ * 默认英文文案
36
+ */
21
37
  export declare const enUSLocale: DateLocaleConfig;
38
+ /**
39
+ * 默认使用中文文案
40
+ */
22
41
  export declare const defaultLocale: DateLocaleConfig;
23
42
  //# sourceMappingURL=locales.d.ts.map
@@ -1,7 +1,11 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.defaultLocale = exports.enUSLocale = exports.zhCNLocale = void 0;
4
- exports.zhCNLocale = {
1
+ /**
2
+ * Date 组件文案配置
3
+ * 支持外部修改文案内容
4
+ */
5
+ /**
6
+ * 默认中文文案
7
+ */
8
+ export const zhCNLocale = {
5
9
  placeholder: '请选择日期',
6
10
  placeholderDateTime: '请选择日期时间',
7
11
  placeholderRange: '选择日期范围',
@@ -20,7 +24,10 @@ exports.zhCNLocale = {
20
24
  quickRangeLastYear: '最近一年',
21
25
  clear: '清除',
22
26
  };
23
- exports.enUSLocale = {
27
+ /**
28
+ * 默认英文文案
29
+ */
30
+ export const enUSLocale = {
24
31
  placeholder: 'Select date',
25
32
  placeholderDateTime: 'Select date and time',
26
33
  placeholderRange: 'Select date range',
@@ -39,4 +46,7 @@ exports.enUSLocale = {
39
46
  quickRangeLastYear: 'Last year',
40
47
  clear: 'Clear',
41
48
  };
42
- exports.defaultLocale = exports.zhCNLocale;
49
+ /**
50
+ * 默认使用中文文案
51
+ */
52
+ export const defaultLocale = zhCNLocale;
@@ -0,0 +1,54 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { cn } from '../lib/utils';
3
+ import { useEffect, useRef, useState } from 'react';
4
+ import { createPortal } from 'react-dom';
5
+ export function Dropdown({ items, children, className, placement = 'bottom-end' }) {
6
+ const [isOpen, setIsOpen] = useState(false);
7
+ const [position, setPosition] = useState({ top: 0, left: 0, width: 0 });
8
+ const triggerRef = useRef(null);
9
+ const dropdownRef = useRef(null);
10
+ // 计算下拉菜单位置
11
+ const updatePosition = () => {
12
+ if (triggerRef.current) {
13
+ const rect = triggerRef.current.getBoundingClientRect();
14
+ setPosition({
15
+ top: rect.bottom + window.scrollY,
16
+ left: placement === 'bottom-end' ? rect.right + window.scrollX : rect.left + window.scrollX,
17
+ width: rect.width,
18
+ });
19
+ }
20
+ };
21
+ // 点击外部关闭
22
+ useEffect(() => {
23
+ if (!isOpen)
24
+ return;
25
+ const handleClickOutside = (event) => {
26
+ if (triggerRef.current &&
27
+ !triggerRef.current.contains(event.target) &&
28
+ dropdownRef.current &&
29
+ !dropdownRef.current.contains(event.target)) {
30
+ setIsOpen(false);
31
+ }
32
+ };
33
+ document.addEventListener('mousedown', handleClickOutside);
34
+ return () => {
35
+ document.removeEventListener('mousedown', handleClickOutside);
36
+ };
37
+ }, [isOpen]);
38
+ const handleToggle = () => {
39
+ if (!isOpen) {
40
+ updatePosition();
41
+ }
42
+ setIsOpen(!isOpen);
43
+ };
44
+ const handleItemClick = (item) => {
45
+ item.onClick?.();
46
+ setIsOpen(false);
47
+ };
48
+ return (_jsxs(_Fragment, { children: [_jsx("div", { ref: triggerRef, className: cn('relative inline-block', className), children: _jsx("div", { onClick: handleToggle, children: children }) }), isOpen &&
49
+ createPortal(_jsx("div", { ref: dropdownRef, className: cn('fixed z-[9999] mt-2 min-w-[120px]', 'bg-white rounded-lg shadow-lg border border-gray-200', 'py-1', 'animate-in fade-in-0 zoom-in-95'), style: {
50
+ top: `${position.top}px`,
51
+ left: placement === 'bottom-end' ? 'auto' : `${position.left}px`,
52
+ right: placement === 'bottom-end' ? `${window.innerWidth - position.left}px` : 'auto',
53
+ }, children: items.map((item) => (_jsxs("button", { onClick: () => handleItemClick(item), className: cn('w-full px-4 py-2.5 text-sm text-left', 'flex items-center gap-2', 'transition-colors', item.danger ? 'text-red-600 hover:bg-red-50' : 'text-gray-700 hover:bg-gray-50'), children: [item.icon && _jsx("span", { className: "flex-shrink-0", children: item.icon }), _jsx("span", { children: item.label })] }, item.key))) }), document.body)] }));
54
+ }
@@ -1,7 +1,13 @@
1
1
  import type { FormProps as RcFormProps } from 'rc-field-form';
2
2
  import type { ReactNode } from 'react';
3
3
  export interface FormProps<T> extends Omit<RcFormProps<T>, 'component'> {
4
+ /**
5
+ * 表单类名
6
+ */
4
7
  className?: string;
8
+ /**
9
+ * 表单内容
10
+ */
5
11
  children?: ReactNode;
6
12
  }
7
13
  declare const Form: {
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { cn } from '../../lib/utils';
3
+ import RcForm from 'rc-field-form';
4
+ const Form = ({ className, children, ...props }) => {
5
+ return (_jsx(RcForm, { ...props, component: "form", className: cn(className), children: children }));
6
+ };
7
+ Form.displayName = 'Form';
8
+ export { Form };
@@ -3,15 +3,36 @@ import type { ReactNode } from 'react';
3
3
  import { type LabelLayout } from '../Label';
4
4
  type FieldProps = Parameters<typeof Field>[0];
5
5
  export interface FormItemProps<T = any> extends Omit<FieldProps, 'children'> {
6
+ /**
7
+ * 表单项类名
8
+ */
6
9
  className?: string;
10
+ /**
11
+ * 标签文本
12
+ */
7
13
  label?: ReactNode;
14
+ /**
15
+ * 标签类名
16
+ */
8
17
  labelClassName?: string;
18
+ /**
19
+ * 是否必填(仅用于显示,实际验证通过 rules 配置)
20
+ */
9
21
  required?: boolean;
22
+ /**
23
+ * 表单项内容
24
+ */
10
25
  children?: ReactNode | ((value: T, onChange: (value: T) => void, meta: {
11
26
  errors: string[];
12
27
  warnings: string[];
13
28
  }) => ReactNode);
29
+ /**
30
+ * 错误信息类名
31
+ */
14
32
  errorClassName?: string;
33
+ /**
34
+ * 是否显示错误信息
35
+ */
15
36
  showError?: boolean;
16
37
  layout?: Required<LabelLayout>['layout'];
17
38
  }
@@ -0,0 +1,43 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn } from '../../lib/utils';
3
+ import { Field } from 'rc-field-form';
4
+ import React, { forwardRef } from 'react';
5
+ import Label from '../Label';
6
+ const FormItemFN = forwardRef(({ className, label, labelClassName, required, children, errorClassName, showError = true, name, rules, layout, ...props }, ref) => {
7
+ return (_jsx(Field, { name: name, rules: rules, ...props, children: (control, meta /** form */) => {
8
+ const { value, onChange, ...restControl } = control;
9
+ const { errors, warnings } = meta;
10
+ const hasError = errors.length > 0;
11
+ const hasWarning = warnings.length > 0;
12
+ // 如果 children 是函数,调用它并传入 value、onChange 和 meta
13
+ const childNode = typeof children === 'function' ? children(value, onChange, meta) : children;
14
+ // 克隆子元素并注入 value 和 onChange
15
+ const childWithProps = childNode && typeof childNode === 'object' && 'props' in childNode
16
+ ? React.cloneElement(childNode, {
17
+ value: value,
18
+ onChange: (val) => {
19
+ // 兼容 Input 组件的 onChange(value, event) 格式
20
+ // Input 组件的 onChange 签名是: (value: string, event: ChangeEvent) => void
21
+ if (typeof val === 'string') {
22
+ // 如果第一个参数是字符串,说明是 Input 组件的格式
23
+ onChange(val);
24
+ }
25
+ else if (val?.target?.value !== undefined) {
26
+ // 原生 input 的 onChange 事件格式
27
+ onChange(val.target.value);
28
+ }
29
+ else {
30
+ // 其他情况直接使用值
31
+ onChange(val);
32
+ }
33
+ },
34
+ ...restControl,
35
+ })
36
+ : childNode;
37
+ const content = _jsx("div", { className: hasError || hasWarning ? 'relative' : '', children: childWithProps });
38
+ return (_jsxs("div", { ref: ref, className: cn(className), children: [label ? (_jsx(Label, { htmlFor: name, label: label, layout: layout, required: required, labelClassName: cn(labelClassName, hasError && 'text-destructive'), children: content })) : (content), showError && hasError && (_jsx("div", { className: cn('text-sm text-destructive', errorClassName), children: errors[0] })), hasWarning && _jsx("div", { className: "text-sm text-yellow-600", children: warnings[0] })] }));
39
+ } }));
40
+ });
41
+ FormItemFN.displayName = 'FormItem';
42
+ const FormItem = FormItemFN;
43
+ export { FormItem };