@_tc/template-core 0.0.1-bate.1 → 0.0.1-bate.11

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 (443) hide show
  1. package/{app → cjs/app}/controller/base.d.ts +1 -2
  2. package/{app → cjs/app}/controller/base.js +0 -3
  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/{app → cjs/app}/controller/view.js +0 -1
  7. package/cjs/app/data/signKey.d.ts +1 -0
  8. package/{app → cjs/app}/data/signKey.js +0 -1
  9. package/cjs/app/extend/db.d.ts +2 -0
  10. package/cjs/app/extend/db.js +12 -0
  11. package/cjs/app/extend/generateErrorMessage.d.ts +7 -0
  12. package/{app → cjs/app}/extend/generateErrorMessage.js +3 -1
  13. package/cjs/app/extend/logger.d.ts +11 -0
  14. package/{app → cjs/app}/extend/logger.js +0 -1
  15. package/cjs/app/extend/parsingParamsOnUrl.d.ts +2 -0
  16. package/{app → cjs/app}/extend/parsingParamsOnUrl.js +0 -1
  17. package/{app → cjs/app}/extend/render-view.d.ts +1 -2
  18. package/{app → cjs/app}/extend/render-view.js +0 -1
  19. package/{app → cjs/app}/middleware/api-params-verify.d.ts +1 -2
  20. package/{app → cjs/app}/middleware/api-params-verify.js +0 -1
  21. package/{app → cjs/app}/middleware/api-sign-verify.d.ts +1 -2
  22. package/{app → cjs/app}/middleware/api-sign-verify.js +0 -1
  23. package/{app → cjs/app}/middleware/error-handle.d.ts +1 -2
  24. package/{app → cjs/app}/middleware/error-handle.js +0 -1
  25. package/{app → cjs/app}/middleware/project-handler.d.ts +1 -2
  26. package/{app → cjs/app}/middleware/project-handler.js +0 -1
  27. package/cjs/app/middleware.d.ts +5 -0
  28. package/{app → cjs/app}/middleware.js +23 -2
  29. package/cjs/app/router/project.d.ts +4 -0
  30. package/{app → cjs/app}/router/project.js +0 -1
  31. package/cjs/app/router/view.d.ts +4 -0
  32. package/{app → cjs/app}/router/view.js +0 -1
  33. package/cjs/app/router-schema/project.d.ts +3 -0
  34. package/{app → cjs/app}/router-schema/project.js +0 -1
  35. package/cjs/app/service/bese.d.ts +10 -0
  36. package/{app → cjs/app}/service/bese.js +0 -1
  37. package/cjs/app/service/project.d.ts +27 -0
  38. package/cjs/app/service/project.js +42 -0
  39. package/cjs/app/type.d.ts +2 -0
  40. package/{app → cjs/app}/type.js +0 -1
  41. package/cjs/app/typings.d.ts +49 -0
  42. package/{app → cjs/app}/typings.js +0 -1
  43. package/cjs/app/view/entry.tpl +30 -0
  44. package/cjs/bundler/dev.d.ts +1 -0
  45. package/cjs/bundler/dev.js +68 -0
  46. package/cjs/bundler/index.d.ts +1 -0
  47. package/cjs/bundler/index.js +18 -0
  48. package/cjs/bundler/prod.d.ts +1 -0
  49. package/cjs/bundler/prod.js +19 -0
  50. package/cjs/bundler/utils.d.ts +7 -0
  51. package/cjs/bundler/utils.js +127 -0
  52. package/cjs/index.d.ts +28 -0
  53. package/{index.js → cjs/index.js} +0 -1
  54. package/cjs/packages/core/env.d.ts +15 -0
  55. package/{packages → cjs/packages}/core/env.js +0 -1
  56. package/cjs/packages/core/index.d.ts +6 -0
  57. package/{packages → cjs/packages}/core/index.js +24 -1
  58. package/cjs/packages/core/loader/config.d.ts +9 -0
  59. package/{packages → cjs/packages}/core/loader/config.js +14 -1
  60. package/cjs/packages/core/loader/controller.d.ts +17 -0
  61. package/{packages → cjs/packages}/core/loader/controller.js +23 -1
  62. package/cjs/packages/core/loader/extend.d.ts +8 -0
  63. package/{packages → cjs/packages}/core/loader/extend.js +8 -1
  64. package/cjs/packages/core/loader/middleware.d.ts +11 -0
  65. package/cjs/packages/core/loader/middleware.js +38 -0
  66. package/cjs/packages/core/loader/model.d.ts +36 -0
  67. package/{packages → cjs/packages}/core/loader/model.js +43 -1
  68. package/cjs/packages/core/loader/router-schema.d.ts +18 -0
  69. package/{packages → cjs/packages}/core/loader/router-schema.js +16 -1
  70. package/{packages → cjs/packages}/core/loader/router.d.ts +5 -1
  71. package/{packages → cjs/packages}/core/loader/router.js +20 -4
  72. package/cjs/packages/core/loader/service.d.ts +17 -0
  73. package/{packages → cjs/packages}/core/loader/service.js +14 -1
  74. package/cjs/packages/core/paths.d.ts +11 -0
  75. package/{packages → cjs/packages}/core/paths.js +0 -1
  76. package/{packages → cjs/packages}/core/types.d.ts +1 -1
  77. package/{packages → cjs/packages}/core/types.js +0 -1
  78. package/{packages → cjs/packages}/utils/getAllFilesInFolder.d.ts +5 -1
  79. package/{packages → cjs/packages}/utils/getAllFilesInFolder.js +0 -1
  80. package/cjs/packages/utils/getAllFnReturnValue.d.ts +0 -0
  81. package/cjs/packages/utils/getAllFnReturnValue.js +6 -0
  82. package/cjs/packages/utils/index.d.ts +4 -0
  83. package/{packages → cjs/packages}/utils/index.js +0 -1
  84. package/{packages → cjs/packages}/utils/loadFile.d.ts +6 -1
  85. package/{packages → cjs/packages}/utils/loadFile.js +9 -1
  86. package/cjs/packages/utils/path.d.ts +24 -0
  87. package/{packages → cjs/packages}/utils/path.js +14 -1
  88. package/cjs/packages/utils/runFileFn.d.ts +5 -0
  89. package/{packages → cjs/packages}/utils/runFileFn.js +0 -1
  90. package/cjs/typings/type.d.ts +4 -0
  91. package/{typings → cjs/typings}/type.js +0 -1
  92. package/esm/app/controller/base.d.ts +14 -0
  93. package/esm/app/controller/base.js +21 -0
  94. package/esm/app/controller/project.d.ts +12 -0
  95. package/{app → esm/app}/controller/project.js +3 -9
  96. package/esm/app/controller/view.d.ts +9 -0
  97. package/esm/app/controller/view.js +12 -0
  98. package/esm/app/data/signKey.js +1 -0
  99. package/esm/app/extend/db.js +9 -0
  100. package/esm/app/extend/generateErrorMessage.js +12 -0
  101. package/esm/app/extend/logger.js +37 -0
  102. package/esm/app/extend/parsingParamsOnUrl.js +20 -0
  103. package/esm/app/extend/render-view.d.ts +5 -0
  104. package/esm/app/extend/render-view.js +16 -0
  105. package/esm/app/middleware/api-params-verify.d.ts +6 -0
  106. package/esm/app/middleware/api-params-verify.js +58 -0
  107. package/esm/app/middleware/api-sign-verify.d.ts +6 -0
  108. package/esm/app/middleware/api-sign-verify.js +23 -0
  109. package/esm/app/middleware/error-handle.d.ts +6 -0
  110. package/esm/app/middleware/error-handle.js +31 -0
  111. package/esm/app/middleware/project-handler.d.ts +5 -0
  112. package/esm/app/middleware/project-handler.js +19 -0
  113. package/esm/app/middleware.js +55 -0
  114. package/esm/app/router/project.js +6 -0
  115. package/esm/app/router/view.js +3 -0
  116. package/esm/app/router-schema/project.js +31 -0
  117. package/esm/app/service/bese.js +12 -0
  118. package/{app → esm/app}/service/project.js +6 -11
  119. package/esm/app/type.js +1 -0
  120. package/esm/app/typings.js +1 -0
  121. package/esm/app/view/entry.tpl +30 -0
  122. package/esm/bundler/dev.d.ts +2 -0
  123. package/esm/bundler/dev.js +29 -0
  124. package/esm/bundler/index.d.ts +2 -0
  125. package/esm/bundler/index.js +14 -0
  126. package/esm/bundler/prod.d.ts +2 -0
  127. package/esm/bundler/prod.js +16 -0
  128. package/esm/bundler/utils.d.ts +8 -0
  129. package/esm/bundler/utils.js +85 -0
  130. package/esm/index.js +13 -0
  131. package/esm/packages/core/env.js +23 -0
  132. package/esm/packages/core/index.js +109 -0
  133. package/esm/packages/core/loader/config.d.ts +10 -0
  134. package/esm/packages/core/loader/config.js +43 -0
  135. package/esm/packages/core/loader/controller.d.ts +18 -0
  136. package/esm/packages/core/loader/controller.js +38 -0
  137. package/esm/packages/core/loader/extend.d.ts +9 -0
  138. package/esm/packages/core/loader/extend.js +39 -0
  139. package/esm/packages/core/loader/middleware.d.ts +12 -0
  140. package/esm/packages/core/loader/middleware.js +36 -0
  141. package/esm/packages/core/loader/model.d.ts +37 -0
  142. package/esm/packages/core/loader/model.js +127 -0
  143. package/esm/packages/core/loader/router-schema.d.ts +19 -0
  144. package/esm/packages/core/loader/router-schema.js +33 -0
  145. package/esm/packages/core/loader/router.d.ts +9 -0
  146. package/esm/packages/core/loader/router.js +57 -0
  147. package/esm/packages/core/loader/service.d.ts +18 -0
  148. package/esm/packages/core/loader/service.js +28 -0
  149. package/esm/packages/core/paths.js +6 -0
  150. package/esm/packages/core/types.d.ts +75 -0
  151. package/esm/packages/core/types.js +1 -0
  152. package/esm/packages/utils/getAllFilesInFolder.d.ts +10 -0
  153. package/esm/packages/utils/getAllFilesInFolder.js +8 -0
  154. package/esm/packages/utils/getAllFnReturnValue.js +6 -0
  155. package/esm/packages/utils/index.js +4 -0
  156. package/esm/packages/utils/loadFile.d.ts +21 -0
  157. package/esm/packages/utils/loadFile.js +63 -0
  158. package/esm/packages/utils/path.d.ts +25 -0
  159. package/esm/packages/utils/path.js +27 -0
  160. package/esm/packages/utils/runFileFn.js +1 -0
  161. package/esm/typings/type.d.ts +5 -0
  162. package/esm/typings/type.js +1 -0
  163. package/fe/frontend/main.d.ts +3 -0
  164. package/fe/frontend/main.js +6 -0
  165. package/fe/frontend/testPage/index.d.ts +3 -0
  166. package/fe/frontend/testPage/index.js +6 -0
  167. package/fe/frontend/testPage/testPage.entry.d.ts +2 -0
  168. package/fe/frontend/testPage/testPage.entry.js +4 -0
  169. package/fe/packages/ui/react/assets/table/no-result.svg +5 -0
  170. package/fe/packages/ui/react/components/Button/Button.d.ts +39 -0
  171. package/fe/packages/ui/react/components/Button/Button.js +42 -0
  172. package/fe/packages/ui/react/components/Button/SumbitButton.d.ts +13 -0
  173. package/fe/packages/ui/react/components/Button/SumbitButton.js +32 -0
  174. package/fe/packages/ui/react/components/Button/index.d.ts +4 -0
  175. package/fe/packages/ui/react/components/Button/index.js +2 -0
  176. package/fe/packages/ui/react/components/Checkbox/Checkbox.d.ts +17 -0
  177. package/fe/packages/ui/react/components/Checkbox/Checkbox.js +37 -0
  178. package/fe/packages/ui/react/components/Checkbox/index.d.ts +2 -0
  179. package/fe/packages/ui/react/components/Checkbox/index.js +1 -0
  180. package/fe/packages/ui/react/components/ConfirmDialog.d.ts +20 -0
  181. package/fe/packages/ui/react/components/ConfirmDialog.js +9 -0
  182. package/fe/packages/ui/react/components/DataTable/ActionBtn.d.ts +6 -0
  183. package/fe/packages/ui/react/components/DataTable/ActionBtn.js +13 -0
  184. package/fe/packages/ui/react/components/DataTable/data-table.d.ts +44 -0
  185. package/fe/packages/ui/react/components/DataTable/data-table.js +141 -0
  186. package/fe/packages/ui/react/components/Date/Calendar.d.ts +35 -0
  187. package/fe/packages/ui/react/components/Date/Calendar.js +215 -0
  188. package/fe/packages/ui/react/components/Date/Date.d.ts +36 -0
  189. package/fe/packages/ui/react/components/Date/Date.js +178 -0
  190. package/fe/packages/ui/react/components/Date/DateTestPage.d.ts +2 -0
  191. package/fe/packages/ui/react/components/Date/DateTestPage.js +29 -0
  192. package/fe/packages/ui/react/components/Date/LocaleContext.d.ts +6 -0
  193. package/fe/packages/ui/react/components/Date/LocaleContext.js +8 -0
  194. package/fe/packages/ui/react/components/Date/LocaleProvider.d.ts +19 -0
  195. package/fe/packages/ui/react/components/Date/LocaleProvider.js +24 -0
  196. package/fe/packages/ui/react/components/Date/TimePicker.d.ts +7 -0
  197. package/fe/packages/ui/react/components/Date/TimePicker.js +76 -0
  198. package/fe/packages/ui/react/components/Date/data.d.ts +6 -0
  199. package/fe/packages/ui/react/components/Date/data.js +4 -0
  200. package/fe/packages/ui/react/components/Date/dateLocaleStore.d.ts +16 -0
  201. package/fe/packages/ui/react/components/Date/dateLocaleStore.js +14 -0
  202. package/fe/packages/ui/react/components/Date/index.d.ts +6 -0
  203. package/fe/packages/ui/react/components/Date/index.js +5 -0
  204. package/fe/packages/ui/react/components/Date/locales.d.ts +42 -0
  205. package/fe/packages/ui/react/components/Date/locales.js +52 -0
  206. package/fe/packages/ui/react/components/Dropdown.d.ts +16 -0
  207. package/fe/packages/ui/react/components/Dropdown.js +54 -0
  208. package/fe/packages/ui/react/components/Form/Form.d.ts +18 -0
  209. package/fe/packages/ui/react/components/Form/Form.js +8 -0
  210. package/fe/packages/ui/react/components/Form/FormItem.d.ts +41 -0
  211. package/fe/packages/ui/react/components/Form/FormItem.js +43 -0
  212. package/fe/packages/ui/react/components/Form/SchemeForm/data.d.ts +51 -0
  213. package/fe/packages/ui/react/components/Form/SchemeForm/data.js +8 -0
  214. package/fe/packages/ui/react/components/Form/SchemeForm/index.d.ts +152 -0
  215. package/fe/packages/ui/react/components/Form/SchemeForm/index.js +69 -0
  216. package/fe/packages/ui/react/components/Form/index.d.ts +5 -0
  217. package/fe/packages/ui/react/components/Form/index.js +4 -0
  218. package/fe/packages/ui/react/components/Form/useForm.d.ts +3 -0
  219. package/fe/packages/ui/react/components/Form/useForm.js +1 -0
  220. package/fe/packages/ui/react/components/ImagePreview/ImagePreview.d.ts +8 -0
  221. package/fe/packages/ui/react/components/ImagePreview/ImagePreview.js +166 -0
  222. package/fe/packages/ui/react/components/ImagePreview/PreviewImage.d.ts +11 -0
  223. package/fe/packages/ui/react/components/ImagePreview/PreviewImage.js +25 -0
  224. package/fe/packages/ui/react/components/ImagePreview/index.d.ts +3 -0
  225. package/fe/packages/ui/react/components/ImagePreview/index.js +2 -0
  226. package/fe/packages/ui/react/components/Input/Input.d.ts +41 -0
  227. package/fe/packages/ui/react/components/Input/Input.js +60 -0
  228. package/fe/packages/ui/react/components/Input/index.d.ts +2 -0
  229. package/fe/packages/ui/react/components/Input/index.js +1 -0
  230. package/fe/packages/ui/react/components/Label/Label.d.ts +51 -0
  231. package/fe/packages/ui/react/components/Label/Label.js +35 -0
  232. package/fe/packages/ui/react/components/Label/index.d.ts +3 -0
  233. package/fe/packages/ui/react/components/Label/index.js +2 -0
  234. package/fe/packages/ui/react/components/Message/Message.d.ts +20 -0
  235. package/fe/packages/ui/react/components/Message/Message.js +55 -0
  236. package/fe/packages/ui/react/components/Message/MessageManager.d.ts +37 -0
  237. package/fe/packages/ui/react/components/Message/MessageManager.js +90 -0
  238. package/fe/packages/ui/react/components/Message/data.d.ts +2 -0
  239. package/fe/packages/ui/react/components/Message/data.js +1 -0
  240. package/fe/packages/ui/react/components/Message/index.d.ts +3 -0
  241. package/fe/packages/ui/react/components/Message/index.js +1 -0
  242. package/fe/packages/ui/react/components/Modal/Modal.d.ts +25 -0
  243. package/fe/packages/ui/react/components/Modal/Modal.js +51 -0
  244. package/fe/packages/ui/react/components/Modal/ModalManager.d.ts +59 -0
  245. package/fe/packages/ui/react/components/Modal/ModalManager.js +89 -0
  246. package/fe/packages/ui/react/components/Modal/index.d.ts +4 -0
  247. package/fe/packages/ui/react/components/Modal/index.js +2 -0
  248. package/fe/packages/ui/react/components/Pagination.d.ts +18 -0
  249. package/fe/packages/ui/react/components/Pagination.js +88 -0
  250. package/fe/packages/ui/react/components/Search/Search.d.ts +17 -0
  251. package/fe/packages/ui/react/components/Search/Search.js +12 -0
  252. package/fe/packages/ui/react/components/Search/index.d.ts +2 -0
  253. package/fe/packages/ui/react/components/Search/index.js +1 -0
  254. package/fe/packages/ui/react/components/Select/Select.d.ts +21 -0
  255. package/fe/packages/ui/react/components/Select/Select.js +180 -0
  256. package/fe/packages/ui/react/components/Select/index.d.ts +2 -0
  257. package/fe/packages/ui/react/components/Select/index.js +1 -0
  258. package/fe/packages/ui/react/components/Skeleton/Skeleton.d.ts +28 -0
  259. package/fe/packages/ui/react/components/Skeleton/Skeleton.js +31 -0
  260. package/fe/packages/ui/react/components/Skeleton/index.d.ts +3 -0
  261. package/fe/packages/ui/react/components/Skeleton/index.js +1 -0
  262. package/fe/packages/ui/react/components/Switch/Switch.d.ts +11 -0
  263. package/fe/packages/ui/react/components/Switch/Switch.js +20 -0
  264. package/fe/packages/ui/react/components/Switch/index.d.ts +2 -0
  265. package/fe/packages/ui/react/components/Switch/index.js +1 -0
  266. package/fe/packages/ui/react/components/TableSearch/TableSearch.d.ts +67 -0
  267. package/fe/packages/ui/react/components/TableSearch/TableSearch.js +119 -0
  268. package/fe/packages/ui/react/components/TableSearch/index.d.ts +2 -0
  269. package/fe/packages/ui/react/components/TableSearch/index.js +1 -0
  270. package/fe/packages/ui/react/components/TableSearch/lang.d.ts +15 -0
  271. package/fe/packages/ui/react/components/TableSearch/lang.js +23 -0
  272. package/fe/packages/ui/react/components/TableSearch/tableSearchLocaleStore.d.ts +9 -0
  273. package/fe/packages/ui/react/components/TableSearch/tableSearchLocaleStore.js +11 -0
  274. package/fe/packages/ui/react/components/Textarea.d.ts +59 -0
  275. package/fe/packages/ui/react/components/Textarea.js +35 -0
  276. package/fe/packages/ui/react/components/Tooltip.d.ts +25 -0
  277. package/fe/packages/ui/react/components/Tooltip.js +118 -0
  278. package/fe/packages/ui/react/components/TreeSelect.d.ts +25 -0
  279. package/fe/packages/ui/react/components/TreeSelect.js +162 -0
  280. package/fe/packages/ui/react/components/Upload/ImageUpload.d.ts +9 -0
  281. package/fe/packages/ui/react/components/Upload/ImageUpload.js +63 -0
  282. package/fe/packages/ui/react/components/Upload/Upload.d.ts +41 -0
  283. package/fe/packages/ui/react/components/Upload/Upload.js +5 -0
  284. package/fe/packages/ui/react/components/Upload/index.d.ts +3 -0
  285. package/fe/packages/ui/react/components/Upload/index.js +2 -0
  286. package/fe/packages/ui/react/components/breadcrumb.d.ts +35 -0
  287. package/fe/packages/ui/react/components/breadcrumb.js +78 -0
  288. package/fe/packages/ui/react/components/hooks/useInputController.d.ts +24 -0
  289. package/fe/packages/ui/react/components/hooks/useInputController.js +45 -0
  290. package/fe/packages/ui/react/components/index.d.ts +24 -0
  291. package/fe/packages/ui/react/components/index.js +23 -0
  292. package/fe/packages/ui/react/components/table.d.ts +17 -0
  293. package/fe/packages/ui/react/components/table.js +20 -0
  294. package/fe/packages/ui/react/components/testPage/index.d.ts +3 -0
  295. package/fe/packages/ui/react/components/testPage/index.js +118 -0
  296. package/fe/packages/ui/react/hooks/useBreadcrumb.d.ts +10 -0
  297. package/fe/packages/ui/react/hooks/useBreadcrumb.js +2 -0
  298. package/fe/packages/ui/react/hooks/useInit.d.ts +3 -0
  299. package/fe/packages/ui/react/hooks/useInit.js +9 -0
  300. package/fe/packages/ui/react/hooks/useLanguage.d.ts +7 -0
  301. package/fe/packages/ui/react/hooks/useLanguage.js +4 -0
  302. package/fe/packages/ui/react/hooks/usePagination.d.ts +16 -0
  303. package/fe/packages/ui/react/hooks/usePagination.js +27 -0
  304. package/fe/packages/ui/react/index.d.ts +3 -0
  305. package/fe/packages/ui/react/index.js +4 -0
  306. package/fe/packages/ui/react/lib/export.d.ts +66 -0
  307. package/fe/packages/ui/react/lib/export.js +138 -0
  308. package/fe/packages/ui/react/lib/utils.d.ts +34 -0
  309. package/fe/packages/ui/react/lib/utils.js +70 -0
  310. package/fe/packages/ui/react/locales/index.d.ts +8 -0
  311. package/fe/packages/ui/react/locales/index.js +6 -0
  312. package/fe/packages/ui/react/stores/breadcrumb.d.ts +15 -0
  313. package/fe/packages/ui/react/stores/breadcrumb.js +66 -0
  314. package/fe/packages/ui/react/stores/language.d.ts +13 -0
  315. package/fe/packages/ui/react/stores/language.js +51 -0
  316. package/{typings/type.d.ts → fe/packages/ui/react/types/index.d.ts} +1 -1
  317. package/fe/packages/ui/react/types/index.js +1 -0
  318. package/package.json +39 -3
  319. package/app/controller/base.d.ts.map +0 -1
  320. package/app/controller/base.js.map +0 -1
  321. package/app/controller/project.d.ts.map +0 -1
  322. package/app/controller/project.js.map +0 -1
  323. package/app/controller/view.d.ts.map +0 -1
  324. package/app/controller/view.js.map +0 -1
  325. package/app/data/signKey.d.ts.map +0 -1
  326. package/app/data/signKey.js.map +0 -1
  327. package/app/extend/db.d.ts.map +0 -1
  328. package/app/extend/db.js +0 -8
  329. package/app/extend/db.js.map +0 -1
  330. package/app/extend/generateErrorMessage.d.ts.map +0 -1
  331. package/app/extend/generateErrorMessage.js.map +0 -1
  332. package/app/extend/logger.d.ts.map +0 -1
  333. package/app/extend/logger.js.map +0 -1
  334. package/app/extend/parsingParamsOnUrl.d.ts.map +0 -1
  335. package/app/extend/parsingParamsOnUrl.js.map +0 -1
  336. package/app/extend/render-view.d.ts.map +0 -1
  337. package/app/extend/render-view.js.map +0 -1
  338. package/app/middleware/api-params-verify.d.ts.map +0 -1
  339. package/app/middleware/api-params-verify.js.map +0 -1
  340. package/app/middleware/api-sign-verify.d.ts.map +0 -1
  341. package/app/middleware/api-sign-verify.js.map +0 -1
  342. package/app/middleware/error-handle.d.ts.map +0 -1
  343. package/app/middleware/error-handle.js.map +0 -1
  344. package/app/middleware/project-handler.d.ts.map +0 -1
  345. package/app/middleware/project-handler.js.map +0 -1
  346. package/app/middleware.d.ts.map +0 -1
  347. package/app/middleware.js.map +0 -1
  348. package/app/router/project.d.ts.map +0 -1
  349. package/app/router/project.js.map +0 -1
  350. package/app/router/view.d.ts.map +0 -1
  351. package/app/router/view.js.map +0 -1
  352. package/app/router-schema/project.d.ts.map +0 -1
  353. package/app/router-schema/project.js.map +0 -1
  354. package/app/service/bese.d.ts.map +0 -1
  355. package/app/service/bese.js.map +0 -1
  356. package/app/service/project.d.ts.map +0 -1
  357. package/app/service/project.js.map +0 -1
  358. package/app/type.d.ts.map +0 -1
  359. package/app/type.js.map +0 -1
  360. package/app/typings.d.ts.map +0 -1
  361. package/app/typings.js.map +0 -1
  362. package/index.d.ts.map +0 -1
  363. package/index.js.map +0 -1
  364. package/model/index.d.ts +0 -2
  365. package/model/index.d.ts.map +0 -1
  366. package/model/index.js +0 -7
  367. package/model/index.js.map +0 -1
  368. package/model/test.d.ts +0 -6
  369. package/model/test.d.ts.map +0 -1
  370. package/model/test.js +0 -6
  371. package/model/test.js.map +0 -1
  372. package/model/test2.d.ts +0 -6
  373. package/model/test2.d.ts.map +0 -1
  374. package/model/test2.js +0 -6
  375. package/model/test2.js.map +0 -1
  376. package/packages/core/env.d.ts.map +0 -1
  377. package/packages/core/env.js.map +0 -1
  378. package/packages/core/index.d.ts.map +0 -1
  379. package/packages/core/index.js.map +0 -1
  380. package/packages/core/loader/config.d.ts +0 -4
  381. package/packages/core/loader/config.d.ts.map +0 -1
  382. package/packages/core/loader/config.js.map +0 -1
  383. package/packages/core/loader/controller.d.ts +0 -4
  384. package/packages/core/loader/controller.d.ts.map +0 -1
  385. package/packages/core/loader/controller.js.map +0 -1
  386. package/packages/core/loader/extend.d.ts +0 -4
  387. package/packages/core/loader/extend.d.ts.map +0 -1
  388. package/packages/core/loader/extend.js.map +0 -1
  389. package/packages/core/loader/middleware.d.ts +0 -4
  390. package/packages/core/loader/middleware.d.ts.map +0 -1
  391. package/packages/core/loader/middleware.js +0 -16
  392. package/packages/core/loader/middleware.js.map +0 -1
  393. package/packages/core/loader/model.d.ts +0 -15
  394. package/packages/core/loader/model.d.ts.map +0 -1
  395. package/packages/core/loader/model.js.map +0 -1
  396. package/packages/core/loader/router-schema.d.ts +0 -4
  397. package/packages/core/loader/router-schema.d.ts.map +0 -1
  398. package/packages/core/loader/router-schema.js.map +0 -1
  399. package/packages/core/loader/router.d.ts.map +0 -1
  400. package/packages/core/loader/router.js.map +0 -1
  401. package/packages/core/loader/service.d.ts +0 -4
  402. package/packages/core/loader/service.d.ts.map +0 -1
  403. package/packages/core/loader/service.js.map +0 -1
  404. package/packages/core/paths.d.ts.map +0 -1
  405. package/packages/core/paths.js.map +0 -1
  406. package/packages/core/types.d.ts.map +0 -1
  407. package/packages/core/types.js.map +0 -1
  408. package/packages/utils/getAllFilesInFolder.d.ts.map +0 -1
  409. package/packages/utils/getAllFilesInFolder.js.map +0 -1
  410. package/packages/utils/getAllFnReturnValue.d.ts.map +0 -1
  411. package/packages/utils/getAllFnReturnValue.js +0 -2
  412. package/packages/utils/getAllFnReturnValue.js.map +0 -1
  413. package/packages/utils/index.d.ts.map +0 -1
  414. package/packages/utils/index.js.map +0 -1
  415. package/packages/utils/loadFile.d.ts.map +0 -1
  416. package/packages/utils/loadFile.js.map +0 -1
  417. package/packages/utils/path.d.ts +0 -7
  418. package/packages/utils/path.d.ts.map +0 -1
  419. package/packages/utils/path.js.map +0 -1
  420. package/packages/utils/runFileFn.d.ts.map +0 -1
  421. package/packages/utils/runFileFn.js.map +0 -1
  422. package/typings/type.d.ts.map +0 -1
  423. package/typings/type.js.map +0 -1
  424. /package/{app → esm/app}/data/signKey.d.ts +0 -0
  425. /package/{app → esm/app}/extend/db.d.ts +0 -0
  426. /package/{app → esm/app}/extend/generateErrorMessage.d.ts +0 -0
  427. /package/{app → esm/app}/extend/logger.d.ts +0 -0
  428. /package/{app → esm/app}/extend/parsingParamsOnUrl.d.ts +0 -0
  429. /package/{app → esm/app}/middleware.d.ts +0 -0
  430. /package/{app → esm/app}/router/project.d.ts +0 -0
  431. /package/{app → esm/app}/router/view.d.ts +0 -0
  432. /package/{app → esm/app}/router-schema/project.d.ts +0 -0
  433. /package/{app → esm/app}/service/bese.d.ts +0 -0
  434. /package/{app → esm/app}/service/project.d.ts +0 -0
  435. /package/{app → esm/app}/type.d.ts +0 -0
  436. /package/{app → esm/app}/typings.d.ts +0 -0
  437. /package/{index.d.ts → esm/index.d.ts} +0 -0
  438. /package/{packages → esm/packages}/core/env.d.ts +0 -0
  439. /package/{packages → esm/packages}/core/index.d.ts +0 -0
  440. /package/{packages → esm/packages}/core/paths.d.ts +0 -0
  441. /package/{packages → esm/packages}/utils/getAllFnReturnValue.d.ts +0 -0
  442. /package/{packages → esm/packages}/utils/index.d.ts +0 -0
  443. /package/{packages → esm/packages}/utils/runFileFn.d.ts +0 -0
@@ -0,0 +1,215 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn } from '../../lib/utils';
3
+ import { addMonths, addYears, eachDayOfInterval, endOfDay, endOfMonth, endOfWeek, format, isAfter, isBefore, isSameDay, isSameMonth, startOfDay, startOfMonth, startOfWeek, subDays, subMonths, subYears, } from 'date-fns';
4
+ import { zhCN } from 'date-fns/locale';
5
+ import { ChevronLeft, ChevronRight, ChevronsLeft, ChevronsRight } from 'lucide-react';
6
+ import { useMemo, useState } from 'react';
7
+ import { ModeType } from './data';
8
+ import { useDateLocale } from './LocaleContext';
9
+ import { TimePicker } from './TimePicker';
10
+ export function Calendar({ mode = ModeType.Single, value, onChange, disabledDate, showTime, className, locale: customLocale, quickRanges, }) {
11
+ const contextLocale = useDateLocale();
12
+ const locale = useMemo(() => ({ ...contextLocale, ...customLocale }), [contextLocale, customLocale]);
13
+ // Pending value for showTime mode (confirmed on button click)
14
+ const [pendingValue, setPendingValue] = useState(value ?? null);
15
+ // 当前显示的月份
16
+ const [currentMonth, setCurrentMonth] = useState(() => {
17
+ if (value instanceof Date)
18
+ return value;
19
+ if (value && 'from' in value && value.from)
20
+ return value.from;
21
+ return new Date();
22
+ });
23
+ // 悬停日期(用于范围选择预览)
24
+ const [hoverDate, setHoverDate] = useState(null);
25
+ // 生成日历网格数据
26
+ const days = useMemo(() => {
27
+ const monthStart = startOfMonth(currentMonth);
28
+ const monthEnd = endOfMonth(monthStart);
29
+ const startDate = startOfWeek(monthStart, { locale: zhCN, weekStartsOn: 0 });
30
+ const endDate = endOfWeek(monthEnd, { locale: zhCN, weekStartsOn: 0 });
31
+ const daysInGrid = eachDayOfInterval({
32
+ start: startDate,
33
+ end: endDate,
34
+ });
35
+ if (daysInGrid.length < 42) {
36
+ const remaining = 42 - daysInGrid.length;
37
+ const lastDay = daysInGrid[daysInGrid.length - 1];
38
+ const extraDays = eachDayOfInterval({
39
+ start: new Date(lastDay.getTime() + 86400000),
40
+ end: new Date(lastDay.getTime() + remaining * 86400000),
41
+ });
42
+ daysInGrid.push(...extraDays);
43
+ }
44
+ return daysInGrid;
45
+ }, [currentMonth]);
46
+ const weekDays = locale.weekDays;
47
+ const isRangeMode = mode === ModeType.Range;
48
+ const builtInQuickRanges = useMemo(() => [
49
+ {
50
+ label: locale.quickRangeToday,
51
+ getRange: () => {
52
+ const today = new Date();
53
+ return { from: startOfDay(today), to: endOfDay(today) };
54
+ },
55
+ },
56
+ {
57
+ label: locale.quickRangeYesterday,
58
+ getRange: () => {
59
+ const yesterday = subDays(new Date(), 1);
60
+ return { from: startOfDay(yesterday), to: endOfDay(yesterday) };
61
+ },
62
+ },
63
+ {
64
+ label: locale.quickRangeLast7Days,
65
+ getRange: () => {
66
+ const end = new Date();
67
+ const start = subDays(end, 6);
68
+ return { from: startOfDay(start), to: endOfDay(end) };
69
+ },
70
+ },
71
+ {
72
+ label: locale.quickRangeLast30Days,
73
+ getRange: () => {
74
+ const end = new Date();
75
+ const start = subDays(end, 29);
76
+ return { from: startOfDay(start), to: endOfDay(end) };
77
+ },
78
+ },
79
+ {
80
+ label: locale.quickRangeThisMonth,
81
+ getRange: () => {
82
+ const today = new Date();
83
+ return { from: startOfMonth(today), to: endOfMonth(today) };
84
+ },
85
+ },
86
+ {
87
+ label: locale.quickRangeLastYear,
88
+ getRange: () => {
89
+ const end = new Date();
90
+ const start = subYears(end, 1);
91
+ return { from: startOfDay(start), to: endOfDay(end) };
92
+ },
93
+ },
94
+ ], [locale]);
95
+ const quickRangePresets = quickRanges && quickRanges.length > 0 ? quickRanges : builtInQuickRanges;
96
+ const handleQuickRangeClick = (getRange) => {
97
+ const range = getRange();
98
+ setCurrentMonth(range.from ?? new Date());
99
+ if (showTime) {
100
+ setPendingValue(range);
101
+ }
102
+ else {
103
+ onChange?.(range);
104
+ }
105
+ };
106
+ const prevMonth = () => setCurrentMonth(subMonths(currentMonth, 1));
107
+ const nextMonth = () => setCurrentMonth(addMonths(currentMonth, 1));
108
+ const prevYear = () => setCurrentMonth(subYears(currentMonth, 1));
109
+ const nextYear = () => setCurrentMonth(addYears(currentMonth, 1));
110
+ const handleDateClick = (date) => {
111
+ if (disabledDate?.(date))
112
+ return;
113
+ // Preserve time when showTime is enabled
114
+ let dateWithTime = date;
115
+ if (showTime && pendingValue instanceof Date) {
116
+ dateWithTime = new Date(date);
117
+ dateWithTime.setHours(pendingValue.getHours());
118
+ dateWithTime.setMinutes(pendingValue.getMinutes());
119
+ dateWithTime.setSeconds(0);
120
+ dateWithTime.setMilliseconds(0);
121
+ }
122
+ if (showTime) {
123
+ // In showTime mode, store in pending value
124
+ if (mode === ModeType.Single) {
125
+ setPendingValue(dateWithTime);
126
+ }
127
+ else {
128
+ const range = pendingValue || { from: undefined, to: undefined };
129
+ if (!range.from || (range.from && range.to)) {
130
+ setPendingValue({ from: dateWithTime, to: undefined });
131
+ }
132
+ else {
133
+ if (isBefore(dateWithTime, range.from)) {
134
+ setPendingValue({ from: dateWithTime, to: range.from });
135
+ }
136
+ else {
137
+ setPendingValue({ from: range.from, to: dateWithTime });
138
+ }
139
+ }
140
+ }
141
+ }
142
+ else {
143
+ // Without showTime, directly call onChange
144
+ if (mode === ModeType.Single) {
145
+ onChange?.(dateWithTime);
146
+ }
147
+ else {
148
+ const range = value || { from: undefined, to: undefined };
149
+ if (!range.from || (range.from && range.to)) {
150
+ onChange?.({ from: dateWithTime, to: undefined });
151
+ }
152
+ else {
153
+ if (isBefore(dateWithTime, range.from)) {
154
+ onChange?.({ from: dateWithTime, to: range.from });
155
+ }
156
+ else {
157
+ onChange?.({ from: range.from, to: dateWithTime });
158
+ }
159
+ }
160
+ }
161
+ }
162
+ };
163
+ const isSelected = (date) => {
164
+ const compareValue = showTime ? pendingValue : value;
165
+ if (mode === ModeType.Single) {
166
+ return compareValue instanceof Date && isSameDay(date, compareValue);
167
+ }
168
+ else {
169
+ const range = compareValue;
170
+ return (range?.from && isSameDay(date, range.from)) || (range?.to && isSameDay(date, range.to));
171
+ }
172
+ };
173
+ const isInRange = (date) => {
174
+ if (mode !== ModeType.Range)
175
+ return false;
176
+ const compareValue = showTime ? pendingValue : value;
177
+ const range = compareValue;
178
+ if (!range?.from)
179
+ return false;
180
+ const end = range.to || hoverDate;
181
+ if (!end)
182
+ return false;
183
+ return (isAfter(date, range.from) && isBefore(date, end)) || (isAfter(date, end) && isBefore(date, range.from));
184
+ };
185
+ const handleConfirm = () => {
186
+ if (pendingValue) {
187
+ onChange?.(pendingValue);
188
+ }
189
+ };
190
+ const handleTimeChangeInternal = (date) => {
191
+ setPendingValue(date);
192
+ };
193
+ return (_jsxs("div", { className: cn('p-3', showTime || isRangeMode ? 'flex flex-col' : 'w-[280px]', className), children: [_jsxs("div", { className: cn('flex', (showTime || isRangeMode) && 'gap-4'), children: [isRangeMode && (_jsxs("div", { className: "w-[140px] pr-3 border-r border-border", children: [_jsx("div", { className: "text-xs font-medium text-muted-foreground mb-2", children: locale.quickRanges }), _jsx("div", { className: "space-y-1", children: quickRangePresets.map((preset) => (_jsx("button", { type: "button", onClick: () => handleQuickRangeClick(preset.getRange), className: cn('w-full text-left text-xs px-2 py-1 rounded', 'text-foreground hover:bg-muted transition-colors'), children: preset.label }, preset.label))) })] })), _jsxs("div", { className: "w-[280px]", children: [_jsxs("div", { className: "flex items-center justify-between mb-4", children: [_jsxs("div", { className: "flex items-center gap-1", children: [_jsx("button", { onClick: prevYear, className: "p-1 hover:bg-muted rounded text-muted-foreground hover:text-foreground transition-colors", type: "button", children: _jsx(ChevronsLeft, { size: 16 }) }), _jsx("button", { onClick: prevMonth, className: "p-1 hover:bg-muted rounded text-muted-foreground hover:text-foreground transition-colors", type: "button", children: _jsx(ChevronLeft, { size: 16 }) })] }), _jsx("div", { className: "font-medium text-sm", children: format(currentMonth, 'yyyy年 M月', { locale: zhCN }) }), _jsxs("div", { className: "flex items-center gap-1", children: [_jsx("button", { onClick: nextMonth, className: "p-1 hover:bg-muted rounded text-muted-foreground hover:text-foreground transition-colors", type: "button", children: _jsx(ChevronRight, { size: 16 }) }), _jsx("button", { onClick: nextYear, className: "p-1 hover:bg-muted rounded text-muted-foreground hover:text-foreground transition-colors", type: "button", children: _jsx(ChevronsRight, { size: 16 }) })] })] }), _jsx("div", { className: "grid grid-cols-7 mb-2", children: weekDays.map((day) => (_jsx("div", { className: "text-center text-xs text-muted-foreground font-medium py-1", children: day }, day))) }), _jsx("div", { className: "grid grid-cols-7 gap-y-1", onMouseLeave: () => setHoverDate(null), children: days.map((date, i) => {
194
+ const selected = isSelected(date);
195
+ const inRange = isInRange(date);
196
+ const isToday = isSameDay(date, new Date());
197
+ const isCurrentMonth = isSameMonth(date, currentMonth);
198
+ const isDisabled = disabledDate?.(date);
199
+ return (_jsx("div", { className: "flex justify-center p-0", children: _jsx("button", { type: "button", onClick: () => handleDateClick(date), onMouseEnter: () => setHoverDate(date), disabled: isDisabled, className: cn('w-8 h-8 flex items-center justify-center rounded text-sm transition-colors relative z-10', !isCurrentMonth && 'text-muted-foreground/40', isCurrentMonth && !selected && !inRange && !isDisabled && 'text-foreground hover:bg-muted', selected && 'bg-theme text-theme-foreground hover:bg-theme/90', inRange && !selected && 'bg-theme/10 text-theme', !selected && !inRange && isToday && 'border border-theme text-theme', isDisabled && 'text-muted-foreground cursor-not-allowed hover:bg-transparent opacity-50'), children: format(date, 'd') }) }, i));
200
+ }) })] }), showTime && (_jsx("div", { className: "flex flex-col border-l border-border pl-4", children: mode === ModeType.Single ? (_jsxs("div", { className: "flex flex-col justify-center h-full", children: [_jsx("div", { className: "text-xs font-medium text-muted-foreground mb-3 text-center", children: locale.selectTime }), _jsx(TimePicker, { value: pendingValue instanceof Date ? pendingValue : undefined, onChange: handleTimeChangeInternal, className: "border-0" })] })) : (
201
+ // Range mode: show two time pickers
202
+ _jsxs("div", { className: "space-y-4 flex flex-col justify-center h-full", children: [_jsxs("div", { children: [_jsx("div", { className: "text-xs font-medium text-muted-foreground mb-2 text-center", children: locale.startTime }), _jsx(TimePicker, { value: pendingValue && 'from' in pendingValue && pendingValue.from ? pendingValue.from : undefined, onChange: (newDate) => {
203
+ const range = pendingValue;
204
+ setPendingValue({
205
+ from: newDate,
206
+ to: range?.to,
207
+ });
208
+ }, className: "border-0" })] }), pendingValue && 'from' in pendingValue && pendingValue.to && (_jsxs("div", { className: "pt-4 border-t border-border", children: [_jsx("div", { className: "text-xs font-medium text-muted-foreground mb-2 text-center", children: locale.endTime }), _jsx(TimePicker, { value: pendingValue.to, onChange: (newDate) => {
209
+ const range = pendingValue;
210
+ setPendingValue({
211
+ from: range?.from,
212
+ to: newDate,
213
+ });
214
+ }, className: "border-0" })] }))] })) }))] }), showTime && (_jsx("div", { className: "pt-3 mt-3 border-t border-border", children: _jsx("button", { type: "button", onClick: handleConfirm, className: cn('w-full py-2 px-4 rounded', 'bg-theme text-theme-foreground', 'hover:bg-theme/90 transition-colors', 'text-sm font-medium'), children: locale.confirm }) }))] }));
215
+ }
@@ -0,0 +1,36 @@
1
+ import { type DateRange, type QuickRangePreset } from './Calendar';
2
+ import { ModeType } from './data';
3
+ import { type DateLocaleConfig } from './locales';
4
+ export type DateChangeStrValue = [string, string] | string;
5
+ type DateBaseValue = Date | DateRange;
6
+ type Dates = DateBaseValue | [Date, Date];
7
+ export type DateValue = Dates | DateChangeStrValue;
8
+ export type DatePickerProps = {
9
+ mode?: ModeType;
10
+ value?: DateValue;
11
+ defaultValue?: DateValue;
12
+ /**
13
+ * @default 'yyyy-MM-dd'
14
+ */
15
+ format?: string;
16
+ placeholder?: string;
17
+ disabled?: boolean;
18
+ allowClear?: boolean;
19
+ showTime?: boolean;
20
+ onChange?: (value?: DateChangeStrValue, date?: Dates) => void;
21
+ disabledDate?: (current: Date) => boolean;
22
+ className?: string;
23
+ /**
24
+ * 自定义文案配置,会覆盖默认文案
25
+ */
26
+ locale?: Partial<DateLocaleConfig>;
27
+ /**
28
+ * 范围模式下的快捷选择配置
29
+ * 不传则使用默认预设
30
+ */
31
+ quickRanges?: QuickRangePreset[];
32
+ };
33
+ declare const DatePicker: import("react").ForwardRefExoticComponent<DatePickerProps & import("react").RefAttributes<HTMLDivElement>>;
34
+ export { DatePicker };
35
+ export type { DateRange };
36
+ //# sourceMappingURL=Date.d.ts.map
@@ -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,2 @@
1
+ export default function DateTestPage(): import("react/jsx-runtime").JSX.Element;
2
+ //# sourceMappingURL=DateTestPage.d.ts.map
@@ -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
+ };
@@ -0,0 +1,19 @@
1
+ import { type ReactNode } from 'react';
2
+ import { type DateLocaleConfig } from './locales';
3
+ export interface DateLocaleProviderProps {
4
+ locale?: DateLocaleConfig;
5
+ children: ReactNode;
6
+ }
7
+ /**
8
+ * Date 组件文案配置 Provider
9
+ * 用于全局设置 Date 组件的文案
10
+ *
11
+ * @example
12
+ * ```tsx
13
+ * <DateLocaleProvider locale={customLocale}>
14
+ * <App />
15
+ * </DateLocaleProvider>
16
+ * ```
17
+ */
18
+ export declare function DateLocaleProvider({ locale, children }: DateLocaleProviderProps): import("react/jsx-runtime").JSX.Element;
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,7 @@
1
+ export interface TimePickerProps {
2
+ value?: Date;
3
+ onChange?: (date: Date) => void;
4
+ className?: string;
5
+ }
6
+ export declare function TimePicker({ value, onChange, className }: TimePickerProps): import("react/jsx-runtime").JSX.Element;
7
+ //# sourceMappingURL=TimePicker.d.ts.map
@@ -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,6 @@
1
+ export declare const ModeType: {
2
+ readonly Single: "single";
3
+ readonly Range: "range";
4
+ };
5
+ export type ModeType = (typeof ModeType)[keyof typeof ModeType];
6
+ //# sourceMappingURL=data.d.ts.map
@@ -0,0 +1,4 @@
1
+ export const ModeType = {
2
+ Single: 'single',
3
+ Range: 'range',
4
+ };