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
@@ -1,6 +1,5 @@
1
1
  import React, { forwardRef, useRef, useState, useEffect, useCallback } from 'react';
2
2
  import { View } from '@tarojs/components';
3
- import type { ITouchEvent } from '@tarojs/components';
4
3
  import { gridStyles } from './Grid.styles';
5
4
  import type { GridProps, GridRef, GridAlign, GridJustify, GridGap, GridCols } from './Grid.types';
6
5
 
@@ -18,10 +17,6 @@ export const GridComponent = forwardRef<GridRef, GridProps>((props, ref) => {
18
17
  className,
19
18
  style,
20
19
  onClick,
21
- onItemHover,
22
- onItemClick,
23
- responsive,
24
- ...restProps
25
20
  } = props;
26
21
 
27
22
  const gridRef = useRef<any>(null);
@@ -59,48 +54,12 @@ export const GridComponent = forwardRef<GridRef, GridProps>((props, ref) => {
59
54
 
60
55
  // 处理点击事件
61
56
  const handleClick = useCallback(
62
- (event: ITouchEvent) => {
57
+ (event: any) => {
63
58
  onClick?.(event);
64
59
  },
65
60
  [onClick],
66
61
  );
67
62
 
68
- // 处理子元素点击事件
69
- const handleItemClick = useCallback(
70
- (index: number, event: ITouchEvent) => {
71
- onItemClick?.(index, event);
72
- },
73
- [onItemClick],
74
- );
75
-
76
- // 处理子元素悬停事件
77
- const handleItemHover = useCallback(
78
- (index: number, event: ITouchEvent) => {
79
- onItemHover?.(index, event);
80
- },
81
- [onItemHover],
82
- );
83
-
84
- // 渲染子元素
85
- const renderChildren = () => {
86
- if (!children) return null;
87
-
88
- const childrenArray = React.Children.toArray(children);
89
-
90
- return childrenArray.map((child, index) => (
91
- <View
92
- key={index}
93
- className="taro-uno-grid__item"
94
- style={gridStyles['getItemStyle'](index, childrenArray.length, internalCols)}
95
- onClick={(e: ITouchEvent) => handleItemClick(index, e)}
96
- onTouchStart={(event) => handleItemHover(index, event as ITouchEvent)}
97
- onTouchEnd={(event) => handleItemHover(index, event as ITouchEvent)}
98
- >
99
- {child}
100
- </View>
101
- ));
102
- };
103
-
104
63
  // 计算样式
105
64
  const gridStyle = gridStyles['getBaseStyle']({
106
65
  cols: internalCols,
@@ -113,9 +72,6 @@ export const GridComponent = forwardRef<GridRef, GridProps>((props, ref) => {
113
72
  style: style || {},
114
73
  });
115
74
 
116
- // 计算响应式样式
117
- const responsiveStyle = responsive ? gridStyles['getResponsiveStyle'](responsive) : {};
118
-
119
75
  // 计算类名
120
76
  const gridClassName = gridStyles['getClassName']({
121
77
  cols: internalCols,
@@ -154,14 +110,8 @@ export const GridComponent = forwardRef<GridRef, GridProps>((props, ref) => {
154
110
  );
155
111
 
156
112
  return (
157
- <View
158
- ref={gridRef}
159
- className={gridClassName}
160
- style={{ ...gridStyle, ...responsiveStyle }}
161
- onClick={handleClick}
162
- {...restProps}
163
- >
164
- {renderChildren()}
113
+ <View ref={gridRef} className={gridClassName} style={{ ...gridStyle, ...style }} onClick={handleClick}>
114
+ {children}
165
115
  </View>
166
116
  );
167
117
  });
@@ -1,38 +1,30 @@
1
- import React, { forwardRef, useImperativeHandle } from 'react'
2
- import { View } from '@tarojs/components'
3
- import { LayoutContentProps, LayoutContentRef } from './Layout.types'
4
- import { getContentStyle } from './Layout.styles'
1
+ import React, { forwardRef, useImperativeHandle } from 'react';
2
+ import { View } from '@tarojs/components';
3
+ import { LayoutContentProps, LayoutContentRef } from './Layout.types';
4
+ import { getContentStyle } from './Layout.styles';
5
5
 
6
- export const LayoutContent = forwardRef<LayoutContentRef, LayoutContentProps>(({
7
- className,
8
- style,
9
- children,
10
- ...props
11
- }, ref) => {
12
- const contentRef = React.useRef<any>(null)
6
+ export const LayoutContent = forwardRef<LayoutContentRef, LayoutContentProps>(
7
+ ({ className, style, children, ...props }, ref) => {
8
+ const contentRef = React.useRef<any>(null);
13
9
 
14
- useImperativeHandle(ref, () => ({
15
- getContent: () => contentRef.current,
16
- }))
10
+ useImperativeHandle(ref, () => ({
11
+ getContent: () => contentRef.current,
12
+ }));
17
13
 
18
- const contentStyle = getContentStyle(style)
19
- const finalStyle = {
20
- ...contentStyle,
21
- ...style,
22
- }
14
+ const contentStyle = getContentStyle(style);
15
+ const finalStyle = {
16
+ ...contentStyle,
17
+ ...style,
18
+ };
23
19
 
24
- return (
25
- <View
26
- ref={contentRef}
27
- className={className}
28
- style={finalStyle}
29
- {...props}
30
- >
31
- {children}
32
- </View>
33
- )
34
- })
20
+ return (
21
+ <View ref={contentRef} className={className} style={finalStyle} {...props}>
22
+ {children}
23
+ </View>
24
+ );
25
+ },
26
+ );
35
27
 
36
- LayoutContent.displayName = 'LayoutContent'
28
+ LayoutContent.displayName = 'LayoutContent';
37
29
 
38
- export default LayoutContent
30
+ export default LayoutContent;
@@ -1,38 +1,30 @@
1
- import React, { forwardRef, useImperativeHandle } from 'react'
2
- import { View } from '@tarojs/components'
3
- import { LayoutFooterProps, LayoutFooterRef } from './Layout.types'
4
- import { getFooterStyle } from './Layout.styles'
1
+ import React, { forwardRef, useImperativeHandle } from 'react';
2
+ import { View } from '@tarojs/components';
3
+ import { LayoutFooterProps, LayoutFooterRef } from './Layout.types';
4
+ import { getFooterStyle } from './Layout.styles';
5
5
 
6
- export const LayoutFooter = forwardRef<LayoutFooterRef, LayoutFooterProps>(({
7
- className,
8
- style,
9
- children,
10
- ...props
11
- }, ref) => {
12
- const footerRef = React.useRef<any>(null)
6
+ export const LayoutFooter = forwardRef<LayoutFooterRef, LayoutFooterProps>(
7
+ ({ className, style, children, ...props }, ref) => {
8
+ const footerRef = React.useRef<any>(null);
13
9
 
14
- useImperativeHandle(ref, () => ({
15
- getFooter: () => footerRef.current,
16
- }))
10
+ useImperativeHandle(ref, () => ({
11
+ getFooter: () => footerRef.current,
12
+ }));
17
13
 
18
- const footerStyle = getFooterStyle(style)
19
- const finalStyle = {
20
- ...footerStyle,
21
- ...style,
22
- }
14
+ const footerStyle = getFooterStyle(style);
15
+ const finalStyle = {
16
+ ...footerStyle,
17
+ ...style,
18
+ };
23
19
 
24
- return (
25
- <View
26
- ref={footerRef}
27
- className={className}
28
- style={finalStyle}
29
- {...props}
30
- >
31
- {children}
32
- </View>
33
- )
34
- })
20
+ return (
21
+ <View ref={footerRef} className={className} style={finalStyle} {...props}>
22
+ {children}
23
+ </View>
24
+ );
25
+ },
26
+ );
35
27
 
36
- LayoutFooter.displayName = 'LayoutFooter'
28
+ LayoutFooter.displayName = 'LayoutFooter';
37
29
 
38
- export default LayoutFooter
30
+ export default LayoutFooter;
@@ -1,38 +1,30 @@
1
- import React, { forwardRef, useImperativeHandle } from 'react'
2
- import { View } from '@tarojs/components'
3
- import { LayoutHeaderProps, LayoutHeaderRef } from './Layout.types'
4
- import { getHeaderStyle } from './Layout.styles'
1
+ import React, { forwardRef, useImperativeHandle } from 'react';
2
+ import { View } from '@tarojs/components';
3
+ import { LayoutHeaderProps, LayoutHeaderRef } from './Layout.types';
4
+ import { getHeaderStyle } from './Layout.styles';
5
5
 
6
- export const LayoutHeader = forwardRef<LayoutHeaderRef, LayoutHeaderProps>(({
7
- className,
8
- style,
9
- children,
10
- ...props
11
- }, ref) => {
12
- const headerRef = React.useRef<any>(null)
6
+ export const LayoutHeader = forwardRef<LayoutHeaderRef, LayoutHeaderProps>(
7
+ ({ className, style, children, ...props }, ref) => {
8
+ const headerRef = React.useRef<any>(null);
13
9
 
14
- useImperativeHandle(ref, () => ({
15
- getHeader: () => headerRef.current,
16
- }))
10
+ useImperativeHandle(ref, () => ({
11
+ getHeader: () => headerRef.current,
12
+ }));
17
13
 
18
- const headerStyle = getHeaderStyle(style)
19
- const finalStyle = {
20
- ...headerStyle,
21
- ...style,
22
- }
14
+ const headerStyle = getHeaderStyle(style);
15
+ const finalStyle = {
16
+ ...headerStyle,
17
+ ...style,
18
+ };
23
19
 
24
- return (
25
- <View
26
- ref={headerRef}
27
- className={className}
28
- style={finalStyle}
29
- {...props}
30
- >
31
- {children}
32
- </View>
33
- )
34
- })
20
+ return (
21
+ <View ref={headerRef} className={className} style={finalStyle} {...props}>
22
+ {children}
23
+ </View>
24
+ );
25
+ },
26
+ );
35
27
 
36
- LayoutHeader.displayName = 'LayoutHeader'
28
+ LayoutHeader.displayName = 'LayoutHeader';
37
29
 
38
- export default LayoutHeader
30
+ export default LayoutHeader;
@@ -48,37 +48,37 @@ export const layoutStyles = {
48
48
  siderExpanded: {
49
49
  width: 200,
50
50
  },
51
- }
51
+ };
52
52
 
53
53
  export const getLayoutStyle = (hasSider?: boolean) => {
54
- const style = { ...layoutStyles.layout }
54
+ const style = { ...layoutStyles.layout };
55
55
  if (hasSider) {
56
- Object.assign(style, layoutStyles.layoutHasSider)
56
+ Object.assign(style, layoutStyles.layoutHasSider);
57
57
  }
58
- return style
59
- }
58
+ return style;
59
+ };
60
60
 
61
61
  export const getHeaderStyle = (customStyle?: React.CSSProperties) => {
62
- return { ...layoutStyles.header, ...customStyle }
63
- }
62
+ return { ...layoutStyles.header, ...customStyle };
63
+ };
64
64
 
65
65
  export const getContentStyle = (customStyle?: React.CSSProperties) => {
66
- return { ...layoutStyles.content, ...customStyle }
67
- }
66
+ return { ...layoutStyles.content, ...customStyle };
67
+ };
68
68
 
69
69
  export const getFooterStyle = (customStyle?: React.CSSProperties) => {
70
- return { ...layoutStyles.footer, ...customStyle }
71
- }
70
+ return { ...layoutStyles.footer, ...customStyle };
71
+ };
72
72
 
73
73
  export const getSiderStyle = (collapsed?: boolean, width?: number | string, customStyle?: React.CSSProperties) => {
74
- const style: React.CSSProperties = { ...layoutStyles.sider }
74
+ const style: React.CSSProperties = { ...layoutStyles.sider };
75
75
  if (collapsed) {
76
- Object.assign(style, layoutStyles.siderCollapsed)
76
+ Object.assign(style, layoutStyles.siderCollapsed);
77
77
  } else {
78
- Object.assign(style, layoutStyles.siderExpanded)
78
+ Object.assign(style, layoutStyles.siderExpanded);
79
79
  }
80
80
  if (width) {
81
- style.width = width
81
+ style.width = width;
82
82
  }
83
- return { ...style, ...customStyle }
84
- }
83
+ return { ...style, ...customStyle };
84
+ };
@@ -1,39 +1,28 @@
1
- import React, { forwardRef, useImperativeHandle } from 'react'
2
- import { View } from '@tarojs/components'
3
- import { LayoutProps, LayoutRef } from './Layout.types'
4
- import { getLayoutStyle } from './Layout.styles'
1
+ import React, { forwardRef, useImperativeHandle } from 'react';
2
+ import { View } from '@tarojs/components';
3
+ import { LayoutProps, LayoutRef } from './Layout.types';
4
+ import { getLayoutStyle } from './Layout.styles';
5
5
 
6
- export const Layout = forwardRef<LayoutRef, LayoutProps>(({
7
- className,
8
- style,
9
- children,
10
- hasSider,
11
- ...props
12
- }, ref) => {
13
- const layoutRef = React.useRef<any>(null)
6
+ export const Layout = forwardRef<LayoutRef, LayoutProps>(({ className, style, children, hasSider, ...props }, ref) => {
7
+ const layoutRef = React.useRef<any>(null);
14
8
 
15
9
  useImperativeHandle(ref, () => ({
16
10
  getLayout: () => layoutRef.current,
17
- }))
11
+ }));
18
12
 
19
- const layoutStyle = getLayoutStyle(hasSider)
13
+ const layoutStyle = getLayoutStyle(hasSider);
20
14
  const finalStyle = {
21
15
  ...layoutStyle,
22
16
  ...style,
23
- }
17
+ };
24
18
 
25
19
  return (
26
- <View
27
- ref={layoutRef}
28
- className={className}
29
- style={finalStyle}
30
- {...props}
31
- >
20
+ <View ref={layoutRef} className={className} style={finalStyle} {...props}>
32
21
  {children}
33
22
  </View>
34
- )
35
- })
23
+ );
24
+ });
36
25
 
37
- Layout.displayName = 'Layout'
26
+ Layout.displayName = 'Layout';
38
27
 
39
- export default Layout
28
+ export default Layout;
@@ -1,58 +1,58 @@
1
- import { ReactNode } from 'react'
2
- import { ViewProps } from '@tarojs/components'
1
+ import { ReactNode } from 'react';
2
+ import { ViewProps } from '@tarojs/components';
3
3
 
4
4
  export interface LayoutProps extends ViewProps {
5
- className?: string
6
- style?: React.CSSProperties
7
- children?: ReactNode
8
- hasSider?: boolean
5
+ className?: string;
6
+ style?: React.CSSProperties;
7
+ children?: ReactNode;
8
+ hasSider?: boolean;
9
9
  }
10
10
 
11
11
  export interface LayoutHeaderProps extends ViewProps {
12
- className?: string
13
- style?: React.CSSProperties
14
- children?: ReactNode
12
+ className?: string;
13
+ style?: React.CSSProperties;
14
+ children?: ReactNode;
15
15
  }
16
16
 
17
17
  export interface LayoutContentProps extends ViewProps {
18
- className?: string
19
- style?: React.CSSProperties
20
- children?: ReactNode
18
+ className?: string;
19
+ style?: React.CSSProperties;
20
+ children?: ReactNode;
21
21
  }
22
22
 
23
23
  export interface LayoutFooterProps extends ViewProps {
24
- className?: string
25
- style?: React.CSSProperties
26
- children?: ReactNode
24
+ className?: string;
25
+ style?: React.CSSProperties;
26
+ children?: ReactNode;
27
27
  }
28
28
 
29
29
  export interface LayoutSiderProps extends ViewProps {
30
- className?: string
31
- style?: React.CSSProperties
32
- children?: ReactNode
33
- width?: number | string
34
- collapsed?: boolean
35
- collapsedWidth?: number | string
36
- onCollapse?: (_collapsed: boolean) => void
30
+ className?: string;
31
+ style?: React.CSSProperties;
32
+ children?: ReactNode;
33
+ width?: number | string;
34
+ collapsed?: boolean;
35
+ collapsedWidth?: number | string;
36
+ onCollapse?: (_collapsed: boolean) => void;
37
37
  }
38
38
 
39
39
  export interface LayoutRef {
40
- getLayout: () => HTMLDivElement | null
40
+ getLayout: () => HTMLDivElement | null;
41
41
  }
42
42
 
43
43
  export interface LayoutHeaderRef {
44
- getHeader: () => HTMLDivElement | null
44
+ getHeader: () => HTMLDivElement | null;
45
45
  }
46
46
 
47
47
  export interface LayoutContentRef {
48
- getContent: () => HTMLDivElement | null
48
+ getContent: () => HTMLDivElement | null;
49
49
  }
50
50
 
51
51
  export interface LayoutFooterRef {
52
- getFooter: () => HTMLDivElement | null
52
+ getFooter: () => HTMLDivElement | null;
53
53
  }
54
54
 
55
55
  export interface LayoutSiderRef {
56
- getSider: () => HTMLDivElement | null
57
- toggleCollapse: () => void
58
- }
56
+ getSider: () => HTMLDivElement | null;
57
+ toggleCollapse: () => void;
58
+ }
@@ -1,56 +1,44 @@
1
- import React, { forwardRef, useImperativeHandle, useState, useCallback } from 'react'
2
- import { View } from '@tarojs/components'
3
- import { LayoutSiderProps, LayoutSiderRef } from './Layout.types'
4
- import { getSiderStyle } from './Layout.styles'
5
-
6
- export const LayoutSider = forwardRef<LayoutSiderRef, LayoutSiderProps>(({
7
- className,
8
- style,
9
- children,
10
- width = 200,
11
- collapsed = false,
12
- collapsedWidth = 80,
13
- onCollapse,
14
- ...props
15
- }, ref) => {
16
- const [isCollapsed, setIsCollapsed] = useState(collapsed)
17
- const siderRef = React.useRef<any>(null)
18
-
19
- const toggleCollapse = useCallback(() => {
20
- const newCollapsed = !isCollapsed
21
- setIsCollapsed(newCollapsed)
22
- onCollapse?.(newCollapsed)
23
- }, [isCollapsed, onCollapse])
24
-
25
- useImperativeHandle(ref, () => ({
26
- getSider: () => siderRef.current,
27
- toggleCollapse,
28
- }))
29
-
30
- React.useEffect(() => {
31
- setIsCollapsed(collapsed)
32
- }, [collapsed])
33
-
34
- const currentWidth = isCollapsed ? collapsedWidth : width
35
-
36
- const siderStyle = getSiderStyle(isCollapsed, currentWidth, style)
37
- const finalStyle = {
38
- ...siderStyle,
39
- ...style,
40
- }
41
-
42
- return (
43
- <View
44
- ref={siderRef}
45
- className={className}
46
- style={finalStyle}
47
- {...props}
48
- >
49
- {children}
50
- </View>
51
- )
52
- })
53
-
54
- LayoutSider.displayName = 'LayoutSider'
55
-
56
- export default LayoutSider
1
+ import React, { forwardRef, useImperativeHandle, useState, useCallback } from 'react';
2
+ import { View } from '@tarojs/components';
3
+ import { LayoutSiderProps, LayoutSiderRef } from './Layout.types';
4
+ import { getSiderStyle } from './Layout.styles';
5
+
6
+ export const LayoutSider = forwardRef<LayoutSiderRef, LayoutSiderProps>(
7
+ ({ className, style, children, width = 200, collapsed = false, collapsedWidth = 80, onCollapse, ...props }, ref) => {
8
+ const [isCollapsed, setIsCollapsed] = useState(collapsed);
9
+ const siderRef = React.useRef<any>(null);
10
+
11
+ const toggleCollapse = useCallback(() => {
12
+ const newCollapsed = !isCollapsed;
13
+ setIsCollapsed(newCollapsed);
14
+ onCollapse?.(newCollapsed);
15
+ }, [isCollapsed, onCollapse]);
16
+
17
+ useImperativeHandle(ref, () => ({
18
+ getSider: () => siderRef.current,
19
+ toggleCollapse,
20
+ }));
21
+
22
+ React.useEffect(() => {
23
+ setIsCollapsed(collapsed);
24
+ }, [collapsed]);
25
+
26
+ const currentWidth = isCollapsed ? collapsedWidth : width;
27
+
28
+ const siderStyle = getSiderStyle(isCollapsed, currentWidth, style);
29
+ const finalStyle = {
30
+ ...siderStyle,
31
+ ...style,
32
+ };
33
+
34
+ return (
35
+ <View ref={siderRef} className={className} style={finalStyle} {...props}>
36
+ {children}
37
+ </View>
38
+ );
39
+ },
40
+ );
41
+
42
+ LayoutSider.displayName = 'LayoutSider';
43
+
44
+ export default LayoutSider;
@@ -3,6 +3,20 @@ export { LayoutHeader } from './Header';
3
3
  export { LayoutContent } from './Content';
4
4
  export { LayoutFooter } from './Footer';
5
5
  export { LayoutSider } from './Sider';
6
- export type { LayoutProps, LayoutRef, LayoutHeaderProps, LayoutContentProps, LayoutFooterProps, LayoutSiderProps } from './Layout.types';
6
+ export type {
7
+ LayoutProps,
8
+ LayoutRef,
9
+ LayoutHeaderProps,
10
+ LayoutContentProps,
11
+ LayoutFooterProps,
12
+ LayoutSiderProps,
13
+ } from './Layout.types';
7
14
  export type { LayoutHeaderRef, LayoutContentRef, LayoutFooterRef, LayoutSiderRef } from './Layout.types';
8
- export { layoutStyles, getLayoutStyle, getHeaderStyle, getContentStyle, getFooterStyle, getSiderStyle } from './Layout.styles';
15
+ export {
16
+ layoutStyles,
17
+ getLayoutStyle,
18
+ getHeaderStyle,
19
+ getContentStyle,
20
+ getFooterStyle,
21
+ getSiderStyle,
22
+ } from './Layout.styles';