taro-uno-ui 0.9.0 → 1.0.1

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 (312) hide show
  1. package/README.md +21 -0
  2. package/dist/js/{index-DffLRSro.js → index-CDFsvu80.js} +15369 -10741
  3. package/dist/js/index-CDFsvu80.js.map +1 -0
  4. package/dist/js/index-DFdcksbe.js.map +1 -1
  5. package/dist/js/index-DXRIkWX1.js.map +1 -1
  6. package/dist/js/{index-6NJ3A1Dn.js → index-JffnTUrv.js} +15430 -10801
  7. package/dist/js/index-JffnTUrv.js.map +1 -0
  8. package/dist/utils/http/request.d.ts +280 -0
  9. package/package.json +14 -10
  10. package/src/components/basic/Button/Button.tsx +53 -13
  11. package/src/components/basic/Button/Button.types.ts +45 -9
  12. package/src/components/basic/Divider/Divider.tsx +60 -29
  13. package/src/components/basic/Icon/Icon.data.ts +474 -0
  14. package/src/components/basic/Icon/Icon.test.tsx +2 -2
  15. package/src/components/basic/Icon/Icon.tsx +48 -35
  16. package/src/components/basic/Icon/IconManager.ts +229 -0
  17. package/src/components/basic/Text/Text.styles.ts +3 -3
  18. package/src/components/basic/Text/Text.types.ts +14 -4
  19. package/src/components/basic/Typography/Typography.styles.ts +10 -9
  20. package/src/components/basic/Typography/Typography.tsx +15 -13
  21. package/src/components/basic/Typography/Typography.types.ts +41 -41
  22. package/src/components/basic/Typography/index.tsx +1 -1
  23. package/src/components/basic/Video/Video.styles.ts +777 -0
  24. package/src/components/basic/Video/Video.test.tsx +490 -0
  25. package/src/components/basic/Video/Video.tsx +1468 -0
  26. package/src/components/basic/Video/Video.types.ts +500 -0
  27. package/src/components/basic/Video/index.tsx +26 -0
  28. package/src/components/basic/index.tsx +13 -15
  29. package/src/components/common/ErrorBoundary.tsx +1 -1
  30. package/src/components/common/LazyComponent.tsx +9 -8
  31. package/src/components/common/SecurityProvider.tsx +2 -14
  32. package/src/components/common/ThemeProvider.tsx +43 -56
  33. package/src/components/common/VirtualList.tsx +187 -205
  34. package/src/components/common/index.tsx +25 -0
  35. package/src/components/display/Avatar/Avatar.styles.ts +1 -1
  36. package/src/components/display/Avatar/Avatar.tsx +6 -19
  37. package/src/components/display/Avatar/Avatar.types.ts +1 -1
  38. package/src/components/display/Avatar/index.ts +1 -1
  39. package/src/components/display/Badge/Badge.tsx +3 -16
  40. package/src/components/display/Badge/Badge.types.ts +1 -1
  41. package/src/components/display/Badge/index.ts +1 -1
  42. package/src/components/display/Calendar/Calendar.styles.ts +36 -36
  43. package/src/components/display/Calendar/Calendar.test.tsx +27 -15
  44. package/src/components/display/Calendar/Calendar.tsx +56 -35
  45. package/src/components/display/Calendar/Calendar.types.ts +1 -1
  46. package/src/components/display/Calendar/index.ts +1 -1
  47. package/src/components/display/Card/Card.styles.ts +2 -2
  48. package/src/components/display/Card/Card.test.tsx +6 -4
  49. package/src/components/display/Card/Card.tsx +1 -1
  50. package/src/components/display/Card/Card.types.ts +4 -4
  51. package/src/components/display/Card/index.ts +1 -1
  52. package/src/components/display/Carousel/Carousel.styles.ts +31 -31
  53. package/src/components/display/Carousel/Carousel.tsx +34 -39
  54. package/src/components/display/Carousel/Carousel.types.ts +1 -1
  55. package/src/components/display/Carousel/index.ts +1 -1
  56. package/src/components/display/List/List.styles.ts +3 -3
  57. package/src/components/display/List/List.tsx +0 -1
  58. package/src/components/display/List/index.ts +1 -1
  59. package/src/components/display/Rate/Rate.styles.ts +5 -17
  60. package/src/components/display/Rate/Rate.tsx +6 -14
  61. package/src/components/display/Rate/Rate.types.ts +4 -3
  62. package/src/components/display/Rate/index.ts +3 -11
  63. package/src/components/display/Table/Table.test.tsx +2 -0
  64. package/src/components/display/Table/Table.tsx +3 -7
  65. package/src/components/display/Table/Table.types.ts +3 -2
  66. package/src/components/display/Tag/Tag.styles.ts +31 -31
  67. package/src/components/display/Tag/Tag.tsx +9 -26
  68. package/src/components/display/Tag/Tag.types.ts +1 -1
  69. package/src/components/display/Tag/index.ts +1 -1
  70. package/src/components/display/Timeline/Timeline.styles.ts +32 -32
  71. package/src/components/display/Timeline/Timeline.tsx +23 -42
  72. package/src/components/display/Timeline/Timeline.types.ts +1 -1
  73. package/src/components/display/Timeline/index.ts +1 -1
  74. package/src/components/display/index.tsx +33 -29
  75. package/src/components/feedback/Loading/Loading.tsx +6 -1
  76. package/src/components/feedback/Loading/index.ts +2 -5
  77. package/src/components/feedback/Message/Message.styles.ts +3 -3
  78. package/src/components/feedback/Message/index.ts +2 -5
  79. package/src/components/feedback/Modal/Modal.styles.ts +1 -1
  80. package/src/components/feedback/Modal/Modal.tsx +9 -31
  81. package/src/components/feedback/Modal/Modal.types.ts +12 -2
  82. package/src/components/feedback/Notification/Notification.styles.ts +49 -39
  83. package/src/components/feedback/Notification/Notification.test.tsx +1 -1
  84. package/src/components/feedback/Notification/Notification.tsx +97 -120
  85. package/src/components/feedback/Notification/Notification.types.ts +11 -8
  86. package/src/components/feedback/Notification/NotificationManager.tsx +135 -106
  87. package/src/components/feedback/Notification/index.ts +10 -3
  88. package/src/components/feedback/Notification/index.tsx +16 -26
  89. package/src/components/feedback/Progress/Progress.styles.ts +23 -14
  90. package/src/components/feedback/Progress/Progress.tsx +93 -113
  91. package/src/components/feedback/Progress/Progress.types.ts +1 -1
  92. package/src/components/feedback/Progress/index.ts +1 -1
  93. package/src/components/feedback/Progress/utils/animation.ts +12 -23
  94. package/src/components/feedback/Progress/utils/index.ts +2 -2
  95. package/src/components/feedback/Progress/utils/progress-calculator.ts +14 -32
  96. package/src/components/feedback/Result/Result.styles.ts +29 -29
  97. package/src/components/feedback/Result/Result.tsx +8 -20
  98. package/src/components/feedback/Result/Result.types.ts +7 -7
  99. package/src/components/feedback/Result/index.tsx +1 -1
  100. package/src/components/feedback/Toast/Toast.styles.ts +1 -1
  101. package/src/components/feedback/Toast/Toast.tsx +25 -13
  102. package/src/components/feedback/Tooltip/Tooltip.examples.tsx +21 -44
  103. package/src/components/feedback/Tooltip/Tooltip.styles.ts +16 -22
  104. package/src/components/feedback/Tooltip/Tooltip.test.tsx +1 -1
  105. package/src/components/feedback/Tooltip/Tooltip.tsx +65 -46
  106. package/src/components/feedback/Tooltip/Tooltip.types.ts +14 -20
  107. package/src/components/feedback/Tooltip/index.ts +1 -1
  108. package/src/components/feedback/Tooltip/index.tsx +12 -24
  109. package/src/components/feedback/index.tsx +54 -42
  110. package/src/components/form/Cascader/Cascader.styles.ts +2 -2
  111. package/src/components/form/Cascader/Cascader.tsx +84 -88
  112. package/src/components/form/Cascader/Cascader.types.ts +49 -50
  113. package/src/components/form/Cascader/hooks/useCascaderFieldNames.ts +11 -8
  114. package/src/components/form/Cascader/hooks/useCascaderOptions.ts +73 -55
  115. package/src/components/form/Cascader/hooks/useCascaderState.ts +31 -25
  116. package/src/components/form/Cascader/index.ts +1 -1
  117. package/src/components/form/Cascader/utils/formatDisplayValue.ts +4 -4
  118. package/src/components/form/Checkbox/Checkbox.styles.ts +83 -84
  119. package/src/components/form/Checkbox/Checkbox.tsx +2 -9
  120. package/src/components/form/Checkbox/CheckboxGroup.tsx +7 -7
  121. package/src/components/form/DatePicker/DatePicker.test.tsx +1 -1
  122. package/src/components/form/DatePicker/DatePicker.tsx +91 -75
  123. package/src/components/form/DatePicker/DatePicker.types.ts +4 -1
  124. package/src/components/form/Form/Form.tsx +66 -504
  125. package/src/components/form/Form/Form.types.ts +16 -1
  126. package/src/components/form/Form/useFormLogic.ts +497 -0
  127. package/src/components/form/Input/Input.styles.ts +8 -1
  128. package/src/components/form/Input/Input.tsx +55 -291
  129. package/src/components/form/Input/Input.types.ts +13 -1
  130. package/src/components/form/Input/useInputLogic.test.ts +82 -0
  131. package/src/components/form/Input/useInputLogic.ts +260 -0
  132. package/src/components/form/InputNumber/InputNumber.styles.ts +76 -25
  133. package/src/components/form/InputNumber/InputNumber.tsx +53 -21
  134. package/src/components/form/InputNumber/InputNumber.types.ts +21 -3
  135. package/src/components/form/InputNumber/components/InputNumberClearButton.tsx +3 -11
  136. package/src/components/form/InputNumber/components/InputNumberControls.tsx +3 -12
  137. package/src/components/form/InputNumber/hooks/index.ts +1 -1
  138. package/src/components/form/InputNumber/hooks/useInputNumberState.ts +7 -9
  139. package/src/components/form/InputNumber/hooks/useInputNumberValidation.ts +18 -17
  140. package/src/components/form/InputNumber/index.ts +7 -7
  141. package/src/components/form/Radio/Radio.styles.ts +1 -8
  142. package/src/components/form/Radio/Radio.tsx +3 -9
  143. package/src/components/form/Radio/Radio.types.ts +5 -1
  144. package/src/components/form/Select/Select.styles.ts +5 -1
  145. package/src/components/form/Select/Select.tsx +15 -15
  146. package/src/components/form/Select/Select.types.ts +2 -1
  147. package/src/components/form/Slider/Slider.styles.ts +13 -13
  148. package/src/components/form/Slider/Slider.tsx +19 -33
  149. package/src/components/form/Slider/Slider.types.ts +14 -12
  150. package/src/components/form/Slider/index.tsx +2 -9
  151. package/src/components/form/Switch/Switch.styles.ts +1 -7
  152. package/src/components/form/Switch/Switch.tsx +7 -13
  153. package/src/components/form/Textarea/Textarea.styles.ts +4 -4
  154. package/src/components/form/Textarea/Textarea.tsx +7 -1
  155. package/src/components/form/Textarea/Textarea.types.ts +4 -1
  156. package/src/components/form/TimePicker/TimePicker.styles.ts +8 -12
  157. package/src/components/form/TimePicker/TimePicker.tsx +122 -100
  158. package/src/components/form/TimePicker/TimePicker.types.ts +2 -2
  159. package/src/components/form/TimePicker/index.ts +1 -1
  160. package/src/components/form/Transfer/Transfer.styles.ts +3 -15
  161. package/src/components/form/Transfer/Transfer.tsx +146 -134
  162. package/src/components/form/Transfer/Transfer.types.ts +34 -26
  163. package/src/components/form/Transfer/components/TransferItem.tsx +55 -62
  164. package/src/components/form/Transfer/components/TransferList.tsx +212 -199
  165. package/src/components/form/Transfer/components/TransferOperations.tsx +52 -55
  166. package/src/components/form/Transfer/components/TransferPagination.tsx +115 -111
  167. package/src/components/form/Transfer/components/TransferSearch.tsx +52 -55
  168. package/src/components/form/Transfer/hooks/useTransferData.ts +91 -81
  169. package/src/components/form/Transfer/hooks/useTransferState.ts +22 -16
  170. package/src/components/form/Transfer/index.ts +2 -8
  171. package/src/components/form/Upload/Upload.styles.ts +21 -21
  172. package/src/components/form/Upload/Upload.tsx +189 -142
  173. package/src/components/form/Upload/Upload.types.ts +31 -31
  174. package/src/components/form/Upload/index.tsx +1 -1
  175. package/src/components/form/index.tsx +60 -29
  176. package/src/components/index.tsx +0 -1
  177. package/src/components/layout/Affix/Affix.styles.ts +16 -11
  178. package/src/components/layout/Affix/Affix.tsx +67 -75
  179. package/src/components/layout/Affix/Affix.types.ts +18 -18
  180. package/src/components/layout/Affix/index.tsx +1 -1
  181. package/src/components/layout/Col/Col.styles.ts +17 -17
  182. package/src/components/layout/Col/Col.test.tsx +7 -5
  183. package/src/components/layout/Col/Col.tsx +3 -21
  184. package/src/components/layout/Col/Col.types.ts +1 -1
  185. package/src/components/layout/Container/Container.styles.ts +3 -1
  186. package/src/components/layout/Container/Container.tsx +2 -11
  187. package/src/components/layout/Grid/Grid.tsx +3 -53
  188. package/src/components/layout/Layout/Content.tsx +24 -32
  189. package/src/components/layout/Layout/Footer.tsx +24 -32
  190. package/src/components/layout/Layout/Header.tsx +24 -32
  191. package/src/components/layout/Layout/Layout.styles.ts +17 -17
  192. package/src/components/layout/Layout/Layout.tsx +14 -25
  193. package/src/components/layout/Layout/Layout.types.ts +29 -29
  194. package/src/components/layout/Layout/Sider.tsx +44 -56
  195. package/src/components/layout/Layout/index.tsx +16 -2
  196. package/src/components/layout/Row/Row.tsx +15 -43
  197. package/src/components/layout/Space/Space.tsx +3 -11
  198. package/src/components/layout/Space/Space.types.ts +1 -1
  199. package/src/components/layout/index.tsx +29 -19
  200. package/src/components/navigation/Menu/Menu.constants.ts +69 -0
  201. package/src/components/navigation/Menu/Menu.stories.tsx +107 -0
  202. package/src/components/navigation/Menu/Menu.styles.ts +25 -37
  203. package/src/components/navigation/Menu/Menu.tsx +8 -11
  204. package/src/components/navigation/Menu/Menu.types.ts +2 -2
  205. package/src/components/navigation/Menu/Menu.utils.ts +17 -17
  206. package/src/components/navigation/Menu/MenuItem.tsx +9 -11
  207. package/src/components/navigation/Menu/SubMenu.tsx +8 -6
  208. package/src/components/navigation/Menu/index.tsx +4 -69
  209. package/src/components/navigation/NavBar/NavBar.styles.ts +1 -1
  210. package/src/components/navigation/NavBar/NavBar.tsx +7 -10
  211. package/src/components/navigation/NavBar/NavBar.types.ts +3 -3
  212. package/src/components/navigation/NavBar/index.tsx +1 -1
  213. package/src/components/navigation/Pagination/Pagination.test.tsx +2 -3
  214. package/src/components/navigation/Pagination/Pagination.tsx +3 -3
  215. package/src/components/navigation/Pagination/Pagination.types.ts +3 -2
  216. package/src/components/navigation/Pagination/index.ts +9 -3
  217. package/src/components/navigation/Steps/Step.tsx +24 -44
  218. package/src/components/navigation/Steps/Steps.styles.ts +28 -13
  219. package/src/components/navigation/Steps/Steps.test.tsx +2 -0
  220. package/src/components/navigation/Steps/Steps.tsx +88 -89
  221. package/src/components/navigation/Steps/Steps.types.ts +30 -30
  222. package/src/components/navigation/Steps/index.tsx +1 -1
  223. package/src/components/navigation/Tabs/Tabs.test.tsx +3 -2
  224. package/src/components/navigation/Tabs/Tabs.types.ts +4 -3
  225. package/src/components/navigation/index.tsx +21 -16
  226. package/src/constants/index.ts +1 -1
  227. package/src/hooks/index.ts +52 -102
  228. package/src/hooks/types.ts +4 -5
  229. package/src/hooks/useAsync.ts +46 -47
  230. package/src/hooks/useClickOutside.ts +52 -0
  231. package/src/hooks/useCounter.ts +87 -0
  232. package/src/hooks/useDebounce.ts +150 -0
  233. package/src/hooks/useDeepCompareEffect.ts +88 -0
  234. package/src/hooks/useEventListener.ts +77 -0
  235. package/src/hooks/useMediaQuery.ts +75 -0
  236. package/src/hooks/useMutation.ts +233 -0
  237. package/src/hooks/usePerformance.ts +1 -64
  238. package/src/hooks/usePlatform.ts +3 -1
  239. package/src/hooks/usePrevious.ts +25 -0
  240. package/src/hooks/useRequest.ts +12 -7
  241. package/src/hooks/useStateManagement.ts +1 -1
  242. package/src/hooks/useStorage.ts +169 -0
  243. package/src/hooks/useStyle.ts +8 -2
  244. package/src/hooks/useToggle.ts +54 -0
  245. package/src/index.ts +34 -9
  246. package/src/theme/ThemeProvider.tsx +3 -7
  247. package/src/theme/ThemeProvider.types.ts +1 -1
  248. package/src/theme/defaults.ts +1 -1
  249. package/src/theme/design-system.ts +2 -2
  250. package/src/theme/design-tokens.ts +85 -99
  251. package/src/theme/generated/dark-theme.scss +1 -1
  252. package/src/theme/generated/tokens.scss +82 -18
  253. package/src/theme/index.ts +8 -29
  254. package/src/theme/responsive.tsx +36 -34
  255. package/src/theme/styles.ts +1 -1
  256. package/src/theme/useThemeUtils.ts +43 -43
  257. package/src/theme/utils.ts +32 -32
  258. package/src/theme/variables.ts +70 -51
  259. package/src/types/accessibility.ts +36 -37
  260. package/src/types/button.ts +25 -27
  261. package/src/types/component-props.ts +6 -1
  262. package/src/types/glob.d.ts +4 -0
  263. package/src/types/index.ts +2 -2
  264. package/src/types/standardized-components.ts +9 -3
  265. package/src/types/utils.ts +13 -23
  266. package/src/utils/__tests__/responsiveUtils.test.ts +5 -4
  267. package/src/utils/abort-controller.ts +48 -0
  268. package/src/utils/cache.ts +2 -6
  269. package/src/utils/createNamespace.ts +4 -4
  270. package/src/utils/environment.ts +26 -6
  271. package/src/utils/error-handler.ts +2 -2
  272. package/src/utils/errorLogger.ts +16 -20
  273. package/src/utils/formatUtils.ts +38 -70
  274. package/src/utils/http/error-codes.ts +314 -0
  275. package/src/utils/http/http-client.test.ts +63 -0
  276. package/src/utils/{network → http}/http-client.ts +45 -35
  277. package/src/utils/http/request-cache.ts +127 -0
  278. package/src/utils/http/request.ts +954 -0
  279. package/src/utils/http/taro-adapter.test.ts +74 -0
  280. package/src/utils/http/taro-adapter.ts +24 -0
  281. package/src/utils/http/types.ts +414 -0
  282. package/src/utils/http/web-adapter.ts +33 -0
  283. package/src/utils/index.ts +5 -8
  284. package/src/utils/inputValidator.ts +17 -14
  285. package/src/utils/performance/performance.ts +60 -71
  286. package/src/utils/responsiveUtils.ts +7 -16
  287. package/src/utils/rtl-support.ts +29 -19
  288. package/src/utils/security/api-security.ts +47 -39
  289. package/src/utils/securityHeaders.ts +61 -67
  290. package/src/utils/typeHelpers.ts +10 -10
  291. package/src/utils/types/dataProcessing.ts +93 -92
  292. package/src/utils/types/typeHelpers.ts +31 -21
  293. package/src/utils/xssProtection.ts +96 -48
  294. package/dist/js/index-6NJ3A1Dn.js.map +0 -1
  295. package/dist/js/index-DffLRSro.js.map +0 -1
  296. package/src/components/form/Input/Input.enhanced.tsx +0 -732
  297. package/src/components/navigation/Menu/__tests__/Menu.test.tsx +0 -687
  298. package/src/components/navigation/Tree/Tree.styles.ts +0 -553
  299. package/src/components/navigation/Tree/Tree.test.basic.tsx +0 -7
  300. package/src/components/navigation/Tree/Tree.test.functional.tsx +0 -496
  301. package/src/components/navigation/Tree/Tree.test.import.check.tsx +0 -6
  302. package/src/components/navigation/Tree/Tree.test.import.tsx +0 -6
  303. package/src/components/navigation/Tree/Tree.test.minimal.tsx +0 -5
  304. package/src/components/navigation/Tree/Tree.test.simple.tsx +0 -30
  305. package/src/components/navigation/Tree/Tree.test.tsx +0 -908
  306. package/src/components/navigation/Tree/Tree.test.working.tsx +0 -673
  307. package/src/components/navigation/Tree/Tree.tsx +0 -600
  308. package/src/components/navigation/Tree/Tree.types.ts +0 -909
  309. package/src/components/navigation/Tree/Tree.utils.ts +0 -452
  310. package/src/components/navigation/Tree/index.ts +0 -33
  311. package/src/components/navigation/Tree/index.tsx +0 -23
  312. package/src/utils/network/http-client.test.ts +0 -18
@@ -34,7 +34,9 @@ export const DatePickerComponent = forwardRef<DatePickerRef, DatePickerProps>((p
34
34
 
35
35
  // 内部状态管理
36
36
  const [internalValue, setInternalValue] = useState<Date | null>(defaultValue || value || null);
37
- const [internalRangeValue, setInternalRangeValue] = useState<{ start: Date; end: Date } | null>(defaultRangeValue || valueRange || null);
37
+ const [internalRangeValue, setInternalRangeValue] = useState<{ start: Date; end: Date } | null>(
38
+ defaultRangeValue || valueRange || null,
39
+ );
38
40
  const [isOpened, setIsOpened] = useState(false);
39
41
  const [isFocused, setIsFocused] = useState(false);
40
42
 
@@ -43,52 +45,61 @@ export const DatePickerComponent = forwardRef<DatePickerRef, DatePickerProps>((p
43
45
  const inputRef = useRef<HTMLInputElement>(null);
44
46
 
45
47
  // 日期格式化函数
46
- const formatDate = useCallback((date: Date | null, formatStr: DatePickerFormat = format): string => {
47
- if (!date) return '';
48
-
49
- const year = date.getFullYear();
50
- const month = String(date.getMonth() + 1).padStart(2, '0');
51
- const day = String(date.getDate()).padStart(2, '0');
52
-
53
- switch (formatStr) {
54
- case 'YYYY-MM-DD':
55
- return `${year}-${month}-${day}`;
56
- case 'YYYY/MM/DD':
57
- return `${year}/${month}/${day}`;
58
- case 'DD/MM/YYYY':
59
- return `${day}/${month}/${year}`;
60
- case 'MM/DD/YYYY':
61
- return `${month}/${day}/${year}`;
62
- case 'YYYY年MM月DD日':
63
- return `${year}年${month}月${day}日`;
64
- default:
65
- return `${year}-${month}-${day}`;
66
- }
67
- }, [format]);
48
+ const formatDate = useCallback(
49
+ (date: Date | null, formatStr: DatePickerFormat = format): string => {
50
+ if (!date) return '';
51
+
52
+ const year = date.getFullYear();
53
+ const month = String(date.getMonth() + 1).padStart(2, '0');
54
+ const day = String(date.getDate()).padStart(2, '0');
55
+
56
+ switch (formatStr) {
57
+ case 'YYYY-MM-DD':
58
+ return `${year}-${month}-${day}`;
59
+ case 'YYYY/MM/DD':
60
+ return `${year}/${month}/${day}`;
61
+ case 'DD/MM/YYYY':
62
+ return `${day}/${month}/${year}`;
63
+ case 'MM/DD/YYYY':
64
+ return `${month}/${day}/${year}`;
65
+ case 'YYYY年MM月DD日':
66
+ return `${year}年${month}月${day}日`;
67
+ default:
68
+ return `${year}-${month}-${day}`;
69
+ }
70
+ },
71
+ [format],
72
+ );
68
73
 
69
74
  // 日期变化处理
70
- const handleDateChange = useCallback((date: Date | null) => {
71
- setInternalValue(date);
72
- const dateString = formatDate(date, format);
73
- onChange?.(date, dateString);
74
- // 如果有自定义日期渲染,自动打开面板
75
- if (dateRender && !isOpened) {
76
- setIsOpened(true);
77
- onOpenChange?.(true);
78
- }
79
- }, [onChange, formatDate, format, dateRender, isOpened, onOpenChange]);
75
+ const handleDateChange = useCallback(
76
+ (date: Date | null) => {
77
+ setInternalValue(date);
78
+ const dateString = formatDate(date, format);
79
+ onChange?.(date, dateString);
80
+ // 如果有自定义日期渲染,自动打开面板
81
+ if (dateRender && !isOpened) {
82
+ setIsOpened(true);
83
+ onOpenChange?.(true);
84
+ }
85
+ },
86
+ [onChange, formatDate, format, dateRender, isOpened, onOpenChange],
87
+ );
80
88
 
81
89
  // 范围日期变化处理
82
- const handleRangeDateChange = useCallback((range: { start: Date; end: Date } | null) => {
83
- setInternalRangeValue(range);
84
- if (range) {
85
- const startString = formatDate(range.start, format);
86
- const endString = formatDate(range.end, format);
87
- onRangeChange?.(range, [startString, endString]);
88
- } else {
89
- onRangeChange?.(null, ['', '']);
90
- }
91
- }, [onRangeChange, formatDate, format]);
90
+ const handleRangeDateChange = useCallback(
91
+ (range: { start: Date; end: Date } | null) => {
92
+ setInternalRangeValue(range);
93
+ if (range) {
94
+ const startString = formatDate(range.start, format);
95
+ const endString = formatDate(range.end, format);
96
+ onRangeChange?.(range, [startString, endString]);
97
+ } else {
98
+ onRangeChange?.(null, ['', '']);
99
+ }
100
+ },
101
+ [onRangeChange, formatDate, format],
102
+ );
92
103
 
93
104
  // 打开/关闭选择器
94
105
  const togglePicker = useCallback(() => {
@@ -136,7 +147,10 @@ export const DatePickerComponent = forwardRef<DatePickerRef, DatePickerProps>((p
136
147
  // 获取格式化范围日期字符串
137
148
  const getRangeDateString = useCallback(() => {
138
149
  if (!internalRangeValue) return null;
139
- return [formatDate(internalRangeValue.start, format), formatDate(internalRangeValue.end, format)] as [string, string];
150
+ return [formatDate(internalRangeValue.start, format), formatDate(internalRangeValue.end, format)] as [
151
+ string,
152
+ string,
153
+ ];
140
154
  }, [internalRangeValue, formatDate, format]);
141
155
 
142
156
  // 打开选择器
@@ -153,27 +167,36 @@ export const DatePickerComponent = forwardRef<DatePickerRef, DatePickerProps>((p
153
167
  }, [onOpenChange]);
154
168
 
155
169
  // 聚焦处理
156
- const handleFocus = useCallback((event: any) => {
157
- setIsFocused(true);
158
- onFocus?.(event);
159
- }, [onFocus]);
170
+ const handleFocus = useCallback(
171
+ (event: any) => {
172
+ setIsFocused(true);
173
+ onFocus?.(event);
174
+ },
175
+ [onFocus],
176
+ );
160
177
 
161
178
  // 失焦处理
162
- const handleBlur = useCallback((event: any) => {
163
- setIsFocused(false);
164
- onBlur?.(event);
165
- }, [onBlur]);
179
+ const handleBlur = useCallback(
180
+ (event: any) => {
181
+ setIsFocused(false);
182
+ onBlur?.(event);
183
+ },
184
+ [onBlur],
185
+ );
166
186
 
167
187
  // 点击处理
168
- const handleClick = useCallback((event: any) => {
169
- onClick?.(event);
170
- togglePicker();
171
- // 自动触发焦点事件以支持测试
172
- if (!isFocused) {
173
- setIsFocused(true);
174
- onFocus?.(event);
175
- }
176
- }, [onClick, togglePicker, isFocused, onFocus]);
188
+ const handleClick = useCallback(
189
+ (event: any) => {
190
+ onClick?.(event);
191
+ togglePicker();
192
+ // 自动触发焦点事件以支持测试
193
+ if (!isFocused) {
194
+ setIsFocused(true);
195
+ onFocus?.(event);
196
+ }
197
+ },
198
+ [onClick, togglePicker, isFocused, onFocus],
199
+ );
177
200
 
178
201
  // 使用 ref 来存储最新的值,确保 getValue 能够立即获取到更新后的值
179
202
  const latestValueRef = useRef<Date | null>(internalValue);
@@ -249,17 +272,16 @@ export const DatePickerComponent = forwardRef<DatePickerRef, DatePickerProps>((p
249
272
  readOnly,
250
273
  opened: isOpened,
251
274
  focused: isFocused,
252
- className
275
+ className,
253
276
  });
254
277
 
255
-
256
278
  return (
257
279
  <View
258
280
  ref={pickerRef}
259
281
  className={`${pickerClassName} taro-uno-h5-datepicker taro-uno-h5-datepicker--${size} taro-uno-h5-datepicker--${variant}${status !== 'normal' ? ` taro-uno-h5-datepicker--${status}` : ''}${disabled || readOnly ? ' taro-uno-h5-datepicker--disabled' : ''}`}
260
282
  style={pickerStyle}
261
283
  onClick={handleClick}
262
- >
284
+ >
263
285
  {/* 输入区域 */}
264
286
  <View
265
287
  className="taro-uno-datepicker__input-wrapper"
@@ -276,7 +298,7 @@ export const DatePickerComponent = forwardRef<DatePickerRef, DatePickerProps>((p
276
298
  value={internalRangeValue ? formatDate(internalRangeValue.start, format) : ''}
277
299
  placeholder={rangePlaceholder[0]}
278
300
  disabled={disabled}
279
- onFocus={handleFocus}
301
+ onFocus={handleFocus}
280
302
  onBlur={handleBlur}
281
303
  />
282
304
  <Text style={DatePickerStyles.getRangeSeparatorStyle()}>至</Text>
@@ -286,7 +308,7 @@ export const DatePickerComponent = forwardRef<DatePickerRef, DatePickerProps>((p
286
308
  value={internalRangeValue ? formatDate(internalRangeValue.end, format) : ''}
287
309
  placeholder={rangePlaceholder[1]}
288
310
  disabled={disabled}
289
- onFocus={handleFocus}
311
+ onFocus={handleFocus}
290
312
  onBlur={handleBlur}
291
313
  />
292
314
  </View>
@@ -299,7 +321,7 @@ export const DatePickerComponent = forwardRef<DatePickerRef, DatePickerProps>((p
299
321
  value={getDateString()}
300
322
  placeholder={placeholder}
301
323
  disabled={disabled}
302
- onFocus={handleFocus}
324
+ onFocus={handleFocus}
303
325
  onBlur={handleBlur}
304
326
  />
305
327
  )}
@@ -334,18 +356,12 @@ export const DatePickerComponent = forwardRef<DatePickerRef, DatePickerProps>((p
334
356
 
335
357
  {/* 自定义日期渲染 */}
336
358
  {dateRender && (
337
- <View className="taro-uno-datepicker__custom-date">
338
- {dateRender(internalValue || new Date())}
339
- </View>
359
+ <View className="taro-uno-datepicker__custom-date">{dateRender(internalValue || new Date())}</View>
340
360
  )}
341
361
  </View>
342
362
 
343
363
  {/* 自定义底部 */}
344
- {renderExtraFooter && (
345
- <View className="taro-uno-datepicker__custom-footer">
346
- {renderExtraFooter()}
347
- </View>
348
- )}
364
+ {renderExtraFooter && <View className="taro-uno-datepicker__custom-footer">{renderExtraFooter()}</View>}
349
365
  </View>
350
366
  </View>
351
367
  )}
@@ -28,7 +28,10 @@ export interface DisabledDate {
28
28
  }
29
29
 
30
30
  /** 日期选择器原生属性类型 */
31
- export type DatePickerNativeProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'onFocus' | 'onBlur' | 'onClick' | 'defaultValue'>;
31
+ export type DatePickerNativeProps = Omit<
32
+ React.HTMLAttributes<HTMLDivElement>,
33
+ 'onChange' | 'onFocus' | 'onBlur' | 'onClick' | 'defaultValue'
34
+ >;
32
35
 
33
36
  /** 日期选择器组件属性接口 */
34
37
  export interface DatePickerProps extends DatePickerNativeProps {