taro-uno-ui 0.9.0 → 1.0.0

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 (647) hide show
  1. package/README.md +21 -0
  2. package/dist/app.config.d.ts +38 -0
  3. package/dist/app.d.ts +6 -0
  4. package/dist/components/basic/Button/Button.d.ts +6 -0
  5. package/dist/components/basic/Button/Button.styles.d.ts +2 -0
  6. package/dist/components/basic/Button/Button.types.d.ts +74 -0
  7. package/dist/components/basic/Button/index.d.ts +4 -0
  8. package/dist/components/basic/Divider/Divider.d.ts +6 -0
  9. package/dist/components/basic/Divider/Divider.styles.d.ts +87 -0
  10. package/dist/components/basic/Divider/Divider.types.d.ts +242 -0
  11. package/dist/components/basic/Divider/index.d.ts +6 -0
  12. package/dist/components/basic/Icon/Icon.d.ts +5 -0
  13. package/dist/components/basic/Icon/Icon.data.d.ts +29 -0
  14. package/dist/components/basic/Icon/Icon.styles.d.ts +61 -0
  15. package/dist/components/basic/Icon/Icon.types.d.ts +199 -0
  16. package/dist/components/basic/Icon/IconManager.d.ts +120 -0
  17. package/dist/components/basic/Icon/index.d.ts +6 -0
  18. package/dist/components/basic/Text/Text.d.ts +7 -0
  19. package/dist/components/basic/Text/Text.styles.d.ts +67 -0
  20. package/dist/components/basic/Text/Text.types.d.ts +274 -0
  21. package/dist/components/basic/Text/index.d.ts +5 -0
  22. package/dist/components/basic/Typography/Typography.d.ts +8 -0
  23. package/dist/components/basic/Typography/Typography.styles.d.ts +83 -0
  24. package/dist/components/basic/Typography/Typography.types.d.ts +245 -0
  25. package/dist/components/basic/Typography/index.d.ts +3 -0
  26. package/dist/components/basic/Video/Video.d.ts +7 -0
  27. package/dist/components/basic/Video/Video.styles.d.ts +212 -0
  28. package/dist/components/basic/Video/Video.types.d.ts +447 -0
  29. package/dist/components/basic/Video/index.d.ts +10 -0
  30. package/dist/components/basic/index.d.ts +217 -0
  31. package/dist/components/common/ErrorBoundary.d.ts +19 -0
  32. package/dist/components/common/LazyComponent.d.ts +78 -0
  33. package/dist/components/common/ResponsiveContainer.d.ts +23 -0
  34. package/dist/components/common/ResponsiveGrid.d.ts +44 -0
  35. package/dist/components/common/SecurityProvider.d.ts +15 -0
  36. package/dist/components/common/ThemeProvider.d.ts +17 -0
  37. package/dist/components/common/VirtualList.d.ts +89 -0
  38. package/dist/components/common/index.d.ts +17 -0
  39. package/dist/components/display/Avatar/Avatar.d.ts +3 -0
  40. package/dist/components/display/Avatar/Avatar.styles.d.ts +2 -0
  41. package/dist/components/display/Avatar/Avatar.types.d.ts +37 -0
  42. package/dist/components/display/Avatar/index.d.ts +3 -0
  43. package/dist/components/display/Badge/Badge.d.ts +3 -0
  44. package/dist/components/display/Badge/Badge.types.d.ts +27 -0
  45. package/dist/components/display/Badge/index.d.ts +2 -0
  46. package/dist/components/display/Calendar/Calendar.d.ts +5 -0
  47. package/dist/components/display/Calendar/Calendar.styles.d.ts +2 -0
  48. package/dist/components/display/Calendar/Calendar.types.d.ts +87 -0
  49. package/dist/components/display/Calendar/index.d.ts +3 -0
  50. package/dist/components/display/Card/Card.d.ts +3 -0
  51. package/dist/components/display/Card/Card.styles.d.ts +1 -0
  52. package/dist/components/display/Card/Card.types.d.ts +52 -0
  53. package/dist/components/display/Card/index.d.ts +3 -0
  54. package/dist/components/display/Carousel/Carousel.d.ts +5 -0
  55. package/dist/components/display/Carousel/Carousel.styles.d.ts +2 -0
  56. package/dist/components/display/Carousel/Carousel.types.d.ts +55 -0
  57. package/dist/components/display/Carousel/index.d.ts +3 -0
  58. package/dist/components/display/List/List.d.ts +4 -0
  59. package/dist/components/display/List/List.styles.d.ts +1 -0
  60. package/dist/components/display/List/List.types.d.ts +64 -0
  61. package/dist/components/display/List/index.d.ts +3 -0
  62. package/dist/components/display/Rate/Rate.d.ts +6 -0
  63. package/dist/components/display/Rate/Rate.styles.d.ts +100 -0
  64. package/dist/components/display/Rate/Rate.types.d.ts +105 -0
  65. package/dist/components/display/Rate/index.d.ts +17 -0
  66. package/dist/components/display/Table/Table.d.ts +7 -0
  67. package/dist/components/display/Table/Table.styles.d.ts +84 -0
  68. package/dist/components/display/Table/Table.types.d.ts +251 -0
  69. package/dist/components/display/Table/index.d.ts +4 -0
  70. package/dist/components/display/Tag/Tag.d.ts +5 -0
  71. package/dist/components/display/Tag/Tag.styles.d.ts +2 -0
  72. package/dist/components/display/Tag/Tag.types.d.ts +47 -0
  73. package/dist/components/display/Tag/index.d.ts +3 -0
  74. package/dist/components/display/Timeline/Timeline.d.ts +16 -0
  75. package/dist/components/display/Timeline/Timeline.styles.d.ts +2 -0
  76. package/dist/components/display/Timeline/Timeline.types.d.ts +53 -0
  77. package/dist/components/display/Timeline/index.d.ts +3 -0
  78. package/dist/components/display/index.d.ts +67 -0
  79. package/dist/components/feedback/Loading/Loading.d.ts +4 -0
  80. package/dist/components/feedback/Loading/Loading.styles.d.ts +2 -0
  81. package/dist/components/feedback/Loading/Loading.types.d.ts +29 -0
  82. package/dist/components/feedback/Loading/index.d.ts +4 -0
  83. package/dist/components/feedback/Message/Message.d.ts +4 -0
  84. package/dist/components/feedback/Message/Message.styles.d.ts +34 -0
  85. package/dist/components/feedback/Message/Message.types.d.ts +33 -0
  86. package/dist/components/feedback/Message/index.d.ts +4 -0
  87. package/dist/components/feedback/Modal/Modal.d.ts +8 -0
  88. package/dist/components/feedback/Modal/Modal.styles.d.ts +18 -0
  89. package/dist/components/feedback/Modal/Modal.types.d.ts +143 -0
  90. package/dist/components/feedback/Modal/index.d.ts +3 -0
  91. package/dist/components/feedback/Notification/Notification.d.ts +4 -0
  92. package/dist/components/feedback/Notification/Notification.styles.d.ts +88 -0
  93. package/dist/components/feedback/Notification/Notification.types.d.ts +279 -0
  94. package/dist/components/feedback/Notification/NotificationManager.d.ts +4 -0
  95. package/dist/components/feedback/Notification/index.d.ts +25 -0
  96. package/dist/components/feedback/Progress/Progress.d.ts +4 -0
  97. package/dist/components/feedback/Progress/Progress.styles.d.ts +261 -0
  98. package/dist/components/feedback/Progress/Progress.test.simple.d.ts +2 -0
  99. package/dist/components/feedback/Progress/Progress.types.d.ts +147 -0
  100. package/dist/components/feedback/Progress/index.d.ts +3 -0
  101. package/dist/components/feedback/Progress/utils/animation.d.ts +55 -0
  102. package/dist/components/feedback/Progress/utils/index.d.ts +2 -0
  103. package/dist/components/feedback/Progress/utils/progress-calculator.d.ts +75 -0
  104. package/dist/components/feedback/Result/Result.d.ts +7 -0
  105. package/dist/components/feedback/Result/Result.styles.d.ts +2 -0
  106. package/dist/components/feedback/Result/Result.types.d.ts +66 -0
  107. package/dist/components/feedback/Result/index.d.ts +3 -0
  108. package/dist/components/feedback/Toast/Toast.d.ts +7 -0
  109. package/dist/components/feedback/Toast/Toast.styles.d.ts +14 -0
  110. package/dist/components/feedback/Toast/Toast.types.d.ts +81 -0
  111. package/dist/components/feedback/Toast/index.d.ts +3 -0
  112. package/dist/components/feedback/Tooltip/Tooltip.d.ts +4 -0
  113. package/dist/components/feedback/Tooltip/Tooltip.examples.d.ts +6 -0
  114. package/dist/components/feedback/Tooltip/Tooltip.styles.d.ts +78 -0
  115. package/dist/components/feedback/Tooltip/Tooltip.types.d.ts +130 -0
  116. package/dist/components/feedback/Tooltip/index.d.ts +3 -0
  117. package/dist/components/feedback/index.d.ts +71 -0
  118. package/dist/components/form/Cascader/Cascader.d.ts +7 -0
  119. package/dist/components/form/Cascader/Cascader.styles.d.ts +107 -0
  120. package/dist/components/form/Cascader/Cascader.types.d.ts +418 -0
  121. package/dist/components/form/Cascader/hooks/index.d.ts +3 -0
  122. package/dist/components/form/Cascader/hooks/useCascaderFieldNames.d.ts +12 -0
  123. package/dist/components/form/Cascader/hooks/useCascaderOptions.d.ts +15 -0
  124. package/dist/components/form/Cascader/hooks/useCascaderState.d.ts +23 -0
  125. package/dist/components/form/Cascader/index.d.ts +6 -0
  126. package/dist/components/form/Cascader/utils/formatDisplayValue.d.ts +9 -0
  127. package/dist/components/form/Cascader/utils/index.d.ts +1 -0
  128. package/dist/components/form/Checkbox/Checkbox.d.ts +6 -0
  129. package/dist/components/form/Checkbox/Checkbox.styles.d.ts +111 -0
  130. package/dist/components/form/Checkbox/Checkbox.types.d.ts +473 -0
  131. package/dist/components/form/Checkbox/CheckboxGroup.d.ts +6 -0
  132. package/dist/components/form/Checkbox/index.d.ts +8 -0
  133. package/dist/components/form/DatePicker/DatePicker.d.ts +6 -0
  134. package/dist/components/form/DatePicker/DatePicker.styles.d.ts +99 -0
  135. package/dist/components/form/DatePicker/DatePicker.types.d.ts +236 -0
  136. package/dist/components/form/DatePicker/index.d.ts +3 -0
  137. package/dist/components/form/Form/Form.d.ts +8 -0
  138. package/dist/components/form/Form/Form.styles.d.ts +84 -0
  139. package/dist/components/form/Form/Form.types.d.ts +416 -0
  140. package/dist/components/form/Form/index.d.ts +9 -0
  141. package/dist/components/form/Form/useFormLogic.d.ts +22 -0
  142. package/dist/components/form/Input/Input.d.ts +6 -0
  143. package/dist/components/form/Input/Input.styles.d.ts +61 -0
  144. package/dist/components/form/Input/Input.types.d.ts +294 -0
  145. package/dist/components/form/Input/index.d.ts +8 -0
  146. package/dist/components/form/Input/useInputLogic.d.ts +35 -0
  147. package/dist/components/form/InputNumber/InputNumber.d.ts +6 -0
  148. package/dist/components/form/InputNumber/InputNumber.styles.d.ts +120 -0
  149. package/dist/components/form/InputNumber/InputNumber.types.d.ts +303 -0
  150. package/dist/components/form/InputNumber/components/InputNumberClearButton.d.ts +10 -0
  151. package/dist/components/form/InputNumber/components/InputNumberControls.d.ts +11 -0
  152. package/dist/components/form/InputNumber/components/index.d.ts +2 -0
  153. package/dist/components/form/InputNumber/hooks/index.d.ts +4 -0
  154. package/dist/components/form/InputNumber/hooks/useInputNumberState.d.ts +38 -0
  155. package/dist/components/form/InputNumber/hooks/useInputNumberValidation.d.ts +12 -0
  156. package/dist/components/form/InputNumber/index.d.ts +5 -0
  157. package/dist/components/form/Radio/Radio.d.ts +6 -0
  158. package/dist/components/form/Radio/Radio.styles.d.ts +80 -0
  159. package/dist/components/form/Radio/Radio.types.d.ts +415 -0
  160. package/dist/components/form/Radio/index.d.ts +8 -0
  161. package/dist/components/form/Select/Select.d.ts +6 -0
  162. package/dist/components/form/Select/Select.styles.d.ts +71 -0
  163. package/dist/components/form/Select/Select.types.d.ts +418 -0
  164. package/dist/components/form/Select/index.d.ts +8 -0
  165. package/dist/components/form/Slider/Slider.d.ts +7 -0
  166. package/dist/components/form/Slider/Slider.styles.d.ts +2 -0
  167. package/dist/components/form/Slider/Slider.types.d.ts +85 -0
  168. package/dist/components/form/Slider/index.d.ts +3 -0
  169. package/dist/components/form/Switch/Switch.d.ts +10 -0
  170. package/dist/components/form/Switch/Switch.styles.d.ts +154 -0
  171. package/dist/components/form/Switch/Switch.types.d.ts +351 -0
  172. package/dist/components/form/Switch/index.d.ts +7 -0
  173. package/dist/components/form/Textarea/Textarea.d.ts +6 -0
  174. package/dist/components/form/Textarea/Textarea.styles.d.ts +66 -0
  175. package/dist/components/form/Textarea/Textarea.types.d.ts +348 -0
  176. package/dist/components/form/Textarea/index.d.ts +7 -0
  177. package/dist/components/form/TimePicker/TimePicker.d.ts +6 -0
  178. package/dist/components/form/TimePicker/TimePicker.styles.d.ts +104 -0
  179. package/dist/components/form/TimePicker/TimePicker.types.d.ts +385 -0
  180. package/dist/components/form/TimePicker/index.d.ts +4 -0
  181. package/dist/components/form/Transfer/Transfer.d.ts +7 -0
  182. package/dist/components/form/Transfer/Transfer.styles.d.ts +106 -0
  183. package/dist/components/form/Transfer/Transfer.types.d.ts +384 -0
  184. package/dist/components/form/Transfer/components/TransferItem.d.ts +23 -0
  185. package/dist/components/form/Transfer/components/TransferList.d.ts +55 -0
  186. package/dist/components/form/Transfer/components/TransferOperations.d.ts +21 -0
  187. package/dist/components/form/Transfer/components/TransferPagination.d.ts +19 -0
  188. package/dist/components/form/Transfer/components/TransferSearch.d.ts +21 -0
  189. package/dist/components/form/Transfer/components/index.d.ts +6 -0
  190. package/dist/components/form/Transfer/hooks/index.d.ts +3 -0
  191. package/dist/components/form/Transfer/hooks/useTransferData.d.ts +41 -0
  192. package/dist/components/form/Transfer/hooks/useTransferState.d.ts +21 -0
  193. package/dist/components/form/Transfer/index.d.ts +9 -0
  194. package/dist/components/form/Upload/Upload.d.ts +7 -0
  195. package/dist/components/form/Upload/Upload.styles.d.ts +2 -0
  196. package/dist/components/form/Upload/Upload.types.d.ts +143 -0
  197. package/dist/components/form/Upload/index.d.ts +3 -0
  198. package/dist/components/form/index.d.ts +126 -0
  199. package/dist/components/index.d.ts +122 -0
  200. package/dist/components/layout/Affix/Affix.d.ts +4 -0
  201. package/dist/components/layout/Affix/Affix.styles.d.ts +1669 -0
  202. package/dist/components/layout/Affix/Affix.types.d.ts +25 -0
  203. package/dist/components/layout/Affix/index.d.ts +3 -0
  204. package/dist/components/layout/Col/Col.d.ts +6 -0
  205. package/dist/components/layout/Col/Col.styles.d.ts +52 -0
  206. package/dist/components/layout/Col/Col.types.d.ts +54 -0
  207. package/dist/components/layout/Col/index.d.ts +3 -0
  208. package/dist/components/layout/Container/Container.d.ts +6 -0
  209. package/dist/components/layout/Container/Container.styles.d.ts +41 -0
  210. package/dist/components/layout/Container/Container.types.d.ts +59 -0
  211. package/dist/components/layout/Container/index.d.ts +3 -0
  212. package/dist/components/layout/Grid/Grid.d.ts +6 -0
  213. package/dist/components/layout/Grid/Grid.styles.d.ts +60 -0
  214. package/dist/components/layout/Grid/Grid.types.d.ts +68 -0
  215. package/dist/components/layout/Grid/index.d.ts +3 -0
  216. package/dist/components/layout/Layout/Content.d.ts +4 -0
  217. package/dist/components/layout/Layout/Footer.d.ts +4 -0
  218. package/dist/components/layout/Layout/Header.d.ts +4 -0
  219. package/dist/components/layout/Layout/Layout.d.ts +4 -0
  220. package/dist/components/layout/Layout/Layout.styles.d.ts +3366 -0
  221. package/dist/components/layout/Layout/Layout.types.d.ts +48 -0
  222. package/dist/components/layout/Layout/Sider.d.ts +4 -0
  223. package/dist/components/layout/Layout/index.d.ts +8 -0
  224. package/dist/components/layout/Row/Row.d.ts +6 -0
  225. package/dist/components/layout/Row/Row.styles.d.ts +55 -0
  226. package/dist/components/layout/Row/Row.types.d.ts +51 -0
  227. package/dist/components/layout/Row/index.d.ts +3 -0
  228. package/dist/components/layout/Space/Space.d.ts +6 -0
  229. package/dist/components/layout/Space/Space.styles.d.ts +69 -0
  230. package/dist/components/layout/Space/Space.types.d.ts +84 -0
  231. package/dist/components/layout/Space/index.d.ts +3 -0
  232. package/dist/components/layout/index.d.ts +39 -0
  233. package/dist/components/navigation/Menu/Menu.constants.d.ts +59 -0
  234. package/dist/components/navigation/Menu/Menu.d.ts +10 -0
  235. package/dist/components/navigation/Menu/Menu.stories.d.ts +157 -0
  236. package/dist/components/navigation/Menu/Menu.styles.d.ts +143 -0
  237. package/dist/components/navigation/Menu/Menu.types.d.ts +210 -0
  238. package/dist/components/navigation/Menu/Menu.utils.d.ts +54 -0
  239. package/dist/components/navigation/Menu/MenuItem.d.ts +32 -0
  240. package/dist/components/navigation/Menu/SubMenu.d.ts +41 -0
  241. package/dist/components/navigation/Menu/index.d.ts +54 -0
  242. package/dist/components/navigation/NavBar/NavBar.d.ts +7 -0
  243. package/dist/components/navigation/NavBar/NavBar.styles.d.ts +114 -0
  244. package/dist/components/navigation/NavBar/NavBar.types.d.ts +50 -0
  245. package/dist/components/navigation/NavBar/index.d.ts +3 -0
  246. package/dist/components/navigation/Pagination/Pagination.d.ts +6 -0
  247. package/dist/components/navigation/Pagination/Pagination.styles.d.ts +55 -0
  248. package/dist/components/navigation/Pagination/Pagination.types.d.ts +77 -0
  249. package/dist/components/navigation/Pagination/index.d.ts +15 -0
  250. package/dist/components/navigation/Steps/Step.d.ts +4 -0
  251. package/dist/components/navigation/Steps/Steps.d.ts +4 -0
  252. package/dist/components/navigation/Steps/Steps.styles.d.ts +6716 -0
  253. package/dist/components/navigation/Steps/Steps.types.d.ts +41 -0
  254. package/dist/components/navigation/Steps/index.d.ts +3 -0
  255. package/dist/components/navigation/Tabs/Tabs.d.ts +6 -0
  256. package/dist/components/navigation/Tabs/Tabs.styles.d.ts +60 -0
  257. package/dist/components/navigation/Tabs/Tabs.types.d.ts +107 -0
  258. package/dist/components/navigation/Tabs/index.d.ts +3 -0
  259. package/dist/components/navigation/index.d.ts +35 -0
  260. package/dist/constants/index.d.ts +624 -0
  261. package/dist/hooks/index.d.ts +28 -0
  262. package/dist/hooks/types.d.ts +7 -0
  263. package/dist/hooks/useAsync.d.ts +17 -0
  264. package/dist/hooks/useClickOutside.d.ts +19 -0
  265. package/dist/hooks/useCounter.d.ts +36 -0
  266. package/dist/hooks/useDebounce.d.ts +31 -0
  267. package/dist/hooks/useDeepCompareEffect.d.ts +22 -0
  268. package/dist/hooks/useEventHandling.d.ts +81 -0
  269. package/dist/hooks/useEventListener.d.ts +19 -0
  270. package/dist/hooks/useLifecycle.d.ts +66 -0
  271. package/dist/hooks/useMediaQuery.d.ts +22 -0
  272. package/dist/hooks/useMutation.d.ts +47 -0
  273. package/dist/hooks/usePerformance.d.ts +73 -0
  274. package/dist/hooks/usePerformanceMonitor.d.ts +66 -0
  275. package/dist/hooks/usePlatform.d.ts +20 -0
  276. package/dist/hooks/usePrevious.d.ts +14 -0
  277. package/dist/hooks/useRequest.d.ts +32 -0
  278. package/dist/hooks/useStateManagement.d.ts +62 -0
  279. package/dist/hooks/useStorage.d.ts +27 -0
  280. package/dist/hooks/useStyle.d.ts +127 -0
  281. package/dist/hooks/useTheme.d.ts +58 -0
  282. package/dist/hooks/useToggle.d.ts +28 -0
  283. package/dist/hooks/useVirtualScroll.d.ts +42 -0
  284. package/dist/index.d.ts +271 -0
  285. package/dist/js/{index-DffLRSro.js → index-CDFsvu80.js} +15369 -10741
  286. package/dist/js/index-CDFsvu80.js.map +1 -0
  287. package/dist/js/index-DFdcksbe.js.map +1 -1
  288. package/dist/js/index-DXRIkWX1.js.map +1 -1
  289. package/dist/js/{index-6NJ3A1Dn.js → index-JffnTUrv.js} +15430 -10801
  290. package/dist/js/index-JffnTUrv.js.map +1 -0
  291. package/dist/platform/index.d.ts +172 -0
  292. package/dist/providers/AppProvider.d.ts +34 -0
  293. package/dist/providers/index.d.ts +1 -0
  294. package/dist/theme/ThemeProvider.d.ts +34 -0
  295. package/dist/theme/ThemeProvider.types.d.ts +21 -0
  296. package/dist/theme/animations.d.ts +96 -0
  297. package/dist/theme/defaults.d.ts +6 -0
  298. package/dist/theme/design-system.d.ts +400 -0
  299. package/dist/theme/design-tokens.d.ts +459 -0
  300. package/dist/theme/index.d.ts +187 -0
  301. package/dist/theme/responsive.d.ts +63 -0
  302. package/dist/theme/styles.d.ts +65 -0
  303. package/dist/theme/tokens/colors.d.ts +72 -0
  304. package/dist/theme/tokens/effects.d.ts +122 -0
  305. package/dist/theme/tokens/index.d.ts +94 -0
  306. package/dist/theme/tokens/spacing.d.ts +65 -0
  307. package/dist/theme/tokens/typography.d.ts +73 -0
  308. package/dist/theme/types.d.ts +153 -0
  309. package/dist/theme/useThemeUtils.d.ts +21 -0
  310. package/dist/theme/utils.d.ts +255 -0
  311. package/dist/theme/variables.d.ts +170 -0
  312. package/dist/types/accessibility.d.ts +46 -0
  313. package/dist/types/button.d.ts +285 -0
  314. package/dist/types/component-props.d.ts +109 -0
  315. package/dist/types/index.d.ts +343 -0
  316. package/dist/types/standardized-components.d.ts +263 -0
  317. package/dist/types/utils.d.ts +190 -0
  318. package/dist/utils/abort-controller.d.ts +19 -0
  319. package/dist/utils/cache.d.ts +28 -0
  320. package/dist/utils/createNamespace.d.ts +9 -0
  321. package/dist/utils/environment.d.ts +26 -0
  322. package/dist/utils/error-handler.d.ts +37 -0
  323. package/dist/utils/errorLogger.d.ts +72 -0
  324. package/dist/utils/formatUtils.d.ts +93 -0
  325. package/dist/utils/http/error-codes.d.ts +131 -0
  326. package/dist/utils/http/http-client.d.ts +53 -0
  327. package/dist/utils/http/request-cache.d.ts +65 -0
  328. package/dist/utils/http/request.d.ts +280 -0
  329. package/dist/utils/http/taro-adapter.d.ts +4 -0
  330. package/dist/utils/http/types.d.ts +351 -0
  331. package/dist/utils/http/web-adapter.d.ts +4 -0
  332. package/dist/utils/index.d.ts +46 -0
  333. package/dist/utils/inputValidator.d.ts +74 -0
  334. package/dist/utils/performance/performance.d.ts +167 -0
  335. package/dist/utils/responsiveUtils.d.ts +148 -0
  336. package/dist/utils/rtl-support.d.ts +78 -0
  337. package/dist/utils/security/api-security.d.ts +82 -0
  338. package/dist/utils/security/xss-protection.d.ts +20 -0
  339. package/dist/utils/securityHeaders.d.ts +74 -0
  340. package/dist/utils/typeHelpers.d.ts +1 -0
  341. package/dist/utils/types/dataProcessing.d.ts +111 -0
  342. package/dist/utils/types/typeHelpers.d.ts +50 -0
  343. package/dist/utils/xssProtection.d.ts +90 -0
  344. package/package.json +14 -10
  345. package/src/components/basic/Button/Button.tsx +53 -13
  346. package/src/components/basic/Button/Button.types.ts +45 -9
  347. package/src/components/basic/Divider/Divider.tsx +60 -29
  348. package/src/components/basic/Icon/Icon.data.ts +474 -0
  349. package/src/components/basic/Icon/Icon.test.tsx +2 -2
  350. package/src/components/basic/Icon/Icon.tsx +48 -35
  351. package/src/components/basic/Icon/IconManager.ts +229 -0
  352. package/src/components/basic/Text/Text.styles.ts +3 -3
  353. package/src/components/basic/Text/Text.types.ts +14 -4
  354. package/src/components/basic/Typography/Typography.styles.ts +10 -9
  355. package/src/components/basic/Typography/Typography.tsx +15 -13
  356. package/src/components/basic/Typography/Typography.types.ts +41 -41
  357. package/src/components/basic/Typography/index.tsx +1 -1
  358. package/src/components/basic/Video/Video.styles.ts +777 -0
  359. package/src/components/basic/Video/Video.test.tsx +490 -0
  360. package/src/components/basic/Video/Video.tsx +1468 -0
  361. package/src/components/basic/Video/Video.types.ts +500 -0
  362. package/src/components/basic/Video/index.tsx +26 -0
  363. package/src/components/basic/index.tsx +13 -15
  364. package/src/components/common/ErrorBoundary.tsx +1 -1
  365. package/src/components/common/LazyComponent.tsx +9 -8
  366. package/src/components/common/SecurityProvider.tsx +2 -14
  367. package/src/components/common/ThemeProvider.tsx +43 -56
  368. package/src/components/common/VirtualList.tsx +187 -205
  369. package/src/components/common/index.tsx +25 -0
  370. package/src/components/display/Avatar/Avatar.styles.ts +1 -1
  371. package/src/components/display/Avatar/Avatar.tsx +6 -19
  372. package/src/components/display/Avatar/Avatar.types.ts +1 -1
  373. package/src/components/display/Avatar/index.ts +1 -1
  374. package/src/components/display/Badge/Badge.tsx +3 -16
  375. package/src/components/display/Badge/Badge.types.ts +1 -1
  376. package/src/components/display/Badge/index.ts +1 -1
  377. package/src/components/display/Calendar/Calendar.styles.ts +36 -36
  378. package/src/components/display/Calendar/Calendar.test.tsx +27 -15
  379. package/src/components/display/Calendar/Calendar.tsx +56 -35
  380. package/src/components/display/Calendar/Calendar.types.ts +1 -1
  381. package/src/components/display/Calendar/index.ts +1 -1
  382. package/src/components/display/Card/Card.styles.ts +2 -2
  383. package/src/components/display/Card/Card.test.tsx +6 -4
  384. package/src/components/display/Card/Card.tsx +1 -1
  385. package/src/components/display/Card/Card.types.ts +4 -4
  386. package/src/components/display/Card/index.ts +1 -1
  387. package/src/components/display/Carousel/Carousel.styles.ts +31 -31
  388. package/src/components/display/Carousel/Carousel.tsx +34 -39
  389. package/src/components/display/Carousel/Carousel.types.ts +1 -1
  390. package/src/components/display/Carousel/index.ts +1 -1
  391. package/src/components/display/List/List.styles.ts +3 -3
  392. package/src/components/display/List/List.tsx +0 -1
  393. package/src/components/display/List/index.ts +1 -1
  394. package/src/components/display/Rate/Rate.styles.ts +5 -17
  395. package/src/components/display/Rate/Rate.tsx +6 -14
  396. package/src/components/display/Rate/Rate.types.ts +4 -3
  397. package/src/components/display/Rate/index.ts +3 -11
  398. package/src/components/display/Table/Table.test.tsx +2 -0
  399. package/src/components/display/Table/Table.tsx +3 -7
  400. package/src/components/display/Table/Table.types.ts +3 -2
  401. package/src/components/display/Tag/Tag.styles.ts +31 -31
  402. package/src/components/display/Tag/Tag.tsx +9 -26
  403. package/src/components/display/Tag/Tag.types.ts +1 -1
  404. package/src/components/display/Tag/index.ts +1 -1
  405. package/src/components/display/Timeline/Timeline.styles.ts +32 -32
  406. package/src/components/display/Timeline/Timeline.tsx +23 -42
  407. package/src/components/display/Timeline/Timeline.types.ts +1 -1
  408. package/src/components/display/Timeline/index.ts +1 -1
  409. package/src/components/display/index.tsx +33 -29
  410. package/src/components/feedback/Loading/Loading.tsx +6 -1
  411. package/src/components/feedback/Loading/index.ts +2 -5
  412. package/src/components/feedback/Message/Message.styles.ts +3 -3
  413. package/src/components/feedback/Message/index.ts +2 -5
  414. package/src/components/feedback/Modal/Modal.styles.ts +1 -1
  415. package/src/components/feedback/Modal/Modal.tsx +9 -31
  416. package/src/components/feedback/Modal/Modal.types.ts +12 -2
  417. package/src/components/feedback/Notification/Notification.styles.ts +49 -39
  418. package/src/components/feedback/Notification/Notification.test.tsx +1 -1
  419. package/src/components/feedback/Notification/Notification.tsx +97 -120
  420. package/src/components/feedback/Notification/Notification.types.ts +11 -8
  421. package/src/components/feedback/Notification/NotificationManager.tsx +135 -106
  422. package/src/components/feedback/Notification/index.ts +10 -3
  423. package/src/components/feedback/Notification/index.tsx +16 -26
  424. package/src/components/feedback/Progress/Progress.styles.ts +23 -14
  425. package/src/components/feedback/Progress/Progress.tsx +93 -113
  426. package/src/components/feedback/Progress/Progress.types.ts +1 -1
  427. package/src/components/feedback/Progress/index.ts +1 -1
  428. package/src/components/feedback/Progress/utils/animation.ts +12 -23
  429. package/src/components/feedback/Progress/utils/index.ts +2 -2
  430. package/src/components/feedback/Progress/utils/progress-calculator.ts +14 -32
  431. package/src/components/feedback/Result/Result.styles.ts +29 -29
  432. package/src/components/feedback/Result/Result.tsx +8 -20
  433. package/src/components/feedback/Result/Result.types.ts +7 -7
  434. package/src/components/feedback/Result/index.tsx +1 -1
  435. package/src/components/feedback/Toast/Toast.styles.ts +1 -1
  436. package/src/components/feedback/Toast/Toast.tsx +25 -13
  437. package/src/components/feedback/Tooltip/Tooltip.examples.tsx +21 -44
  438. package/src/components/feedback/Tooltip/Tooltip.styles.ts +16 -22
  439. package/src/components/feedback/Tooltip/Tooltip.test.tsx +1 -1
  440. package/src/components/feedback/Tooltip/Tooltip.tsx +65 -46
  441. package/src/components/feedback/Tooltip/Tooltip.types.ts +14 -20
  442. package/src/components/feedback/Tooltip/index.ts +1 -1
  443. package/src/components/feedback/Tooltip/index.tsx +12 -24
  444. package/src/components/feedback/index.tsx +54 -42
  445. package/src/components/form/Cascader/Cascader.styles.ts +2 -2
  446. package/src/components/form/Cascader/Cascader.tsx +84 -88
  447. package/src/components/form/Cascader/Cascader.types.ts +49 -50
  448. package/src/components/form/Cascader/hooks/useCascaderFieldNames.ts +11 -8
  449. package/src/components/form/Cascader/hooks/useCascaderOptions.ts +73 -55
  450. package/src/components/form/Cascader/hooks/useCascaderState.ts +31 -25
  451. package/src/components/form/Cascader/index.ts +1 -1
  452. package/src/components/form/Cascader/utils/formatDisplayValue.ts +4 -4
  453. package/src/components/form/Checkbox/Checkbox.styles.ts +83 -84
  454. package/src/components/form/Checkbox/Checkbox.tsx +2 -9
  455. package/src/components/form/Checkbox/CheckboxGroup.tsx +7 -7
  456. package/src/components/form/DatePicker/DatePicker.test.tsx +1 -1
  457. package/src/components/form/DatePicker/DatePicker.tsx +91 -75
  458. package/src/components/form/DatePicker/DatePicker.types.ts +4 -1
  459. package/src/components/form/Form/Form.tsx +66 -504
  460. package/src/components/form/Form/Form.types.ts +16 -1
  461. package/src/components/form/Form/useFormLogic.ts +497 -0
  462. package/src/components/form/Input/Input.styles.ts +8 -1
  463. package/src/components/form/Input/Input.tsx +55 -291
  464. package/src/components/form/Input/Input.types.ts +13 -1
  465. package/src/components/form/Input/useInputLogic.test.ts +82 -0
  466. package/src/components/form/Input/useInputLogic.ts +260 -0
  467. package/src/components/form/InputNumber/InputNumber.styles.ts +76 -25
  468. package/src/components/form/InputNumber/InputNumber.tsx +53 -21
  469. package/src/components/form/InputNumber/InputNumber.types.ts +21 -3
  470. package/src/components/form/InputNumber/components/InputNumberClearButton.tsx +3 -11
  471. package/src/components/form/InputNumber/components/InputNumberControls.tsx +3 -12
  472. package/src/components/form/InputNumber/hooks/index.ts +1 -1
  473. package/src/components/form/InputNumber/hooks/useInputNumberState.ts +7 -9
  474. package/src/components/form/InputNumber/hooks/useInputNumberValidation.ts +18 -17
  475. package/src/components/form/InputNumber/index.ts +7 -7
  476. package/src/components/form/Radio/Radio.styles.ts +1 -8
  477. package/src/components/form/Radio/Radio.tsx +3 -9
  478. package/src/components/form/Radio/Radio.types.ts +5 -1
  479. package/src/components/form/Select/Select.styles.ts +5 -1
  480. package/src/components/form/Select/Select.tsx +15 -15
  481. package/src/components/form/Select/Select.types.ts +2 -1
  482. package/src/components/form/Slider/Slider.styles.ts +13 -13
  483. package/src/components/form/Slider/Slider.tsx +19 -33
  484. package/src/components/form/Slider/Slider.types.ts +14 -12
  485. package/src/components/form/Slider/index.tsx +2 -9
  486. package/src/components/form/Switch/Switch.styles.ts +1 -7
  487. package/src/components/form/Switch/Switch.tsx +7 -13
  488. package/src/components/form/Textarea/Textarea.styles.ts +4 -4
  489. package/src/components/form/Textarea/Textarea.tsx +7 -1
  490. package/src/components/form/Textarea/Textarea.types.ts +4 -1
  491. package/src/components/form/TimePicker/TimePicker.styles.ts +8 -12
  492. package/src/components/form/TimePicker/TimePicker.tsx +122 -100
  493. package/src/components/form/TimePicker/TimePicker.types.ts +2 -2
  494. package/src/components/form/TimePicker/index.ts +1 -1
  495. package/src/components/form/Transfer/Transfer.styles.ts +3 -15
  496. package/src/components/form/Transfer/Transfer.tsx +146 -134
  497. package/src/components/form/Transfer/Transfer.types.ts +34 -26
  498. package/src/components/form/Transfer/components/TransferItem.tsx +55 -62
  499. package/src/components/form/Transfer/components/TransferList.tsx +212 -199
  500. package/src/components/form/Transfer/components/TransferOperations.tsx +52 -55
  501. package/src/components/form/Transfer/components/TransferPagination.tsx +115 -111
  502. package/src/components/form/Transfer/components/TransferSearch.tsx +52 -55
  503. package/src/components/form/Transfer/hooks/useTransferData.ts +91 -81
  504. package/src/components/form/Transfer/hooks/useTransferState.ts +22 -16
  505. package/src/components/form/Transfer/index.ts +2 -8
  506. package/src/components/form/Upload/Upload.styles.ts +21 -21
  507. package/src/components/form/Upload/Upload.tsx +189 -142
  508. package/src/components/form/Upload/Upload.types.ts +31 -31
  509. package/src/components/form/Upload/index.tsx +1 -1
  510. package/src/components/form/index.tsx +60 -29
  511. package/src/components/index.tsx +0 -1
  512. package/src/components/layout/Affix/Affix.styles.ts +16 -11
  513. package/src/components/layout/Affix/Affix.tsx +67 -75
  514. package/src/components/layout/Affix/Affix.types.ts +18 -18
  515. package/src/components/layout/Affix/index.tsx +1 -1
  516. package/src/components/layout/Col/Col.styles.ts +17 -17
  517. package/src/components/layout/Col/Col.test.tsx +7 -5
  518. package/src/components/layout/Col/Col.tsx +3 -21
  519. package/src/components/layout/Col/Col.types.ts +1 -1
  520. package/src/components/layout/Container/Container.styles.ts +3 -1
  521. package/src/components/layout/Container/Container.tsx +2 -11
  522. package/src/components/layout/Grid/Grid.tsx +3 -53
  523. package/src/components/layout/Layout/Content.tsx +24 -32
  524. package/src/components/layout/Layout/Footer.tsx +24 -32
  525. package/src/components/layout/Layout/Header.tsx +24 -32
  526. package/src/components/layout/Layout/Layout.styles.ts +17 -17
  527. package/src/components/layout/Layout/Layout.tsx +14 -25
  528. package/src/components/layout/Layout/Layout.types.ts +29 -29
  529. package/src/components/layout/Layout/Sider.tsx +44 -56
  530. package/src/components/layout/Layout/index.tsx +16 -2
  531. package/src/components/layout/Row/Row.tsx +15 -43
  532. package/src/components/layout/Space/Space.tsx +3 -11
  533. package/src/components/layout/Space/Space.types.ts +1 -1
  534. package/src/components/layout/index.tsx +29 -19
  535. package/src/components/navigation/Menu/Menu.constants.ts +69 -0
  536. package/src/components/navigation/Menu/Menu.stories.tsx +107 -0
  537. package/src/components/navigation/Menu/Menu.styles.ts +25 -37
  538. package/src/components/navigation/Menu/Menu.tsx +8 -11
  539. package/src/components/navigation/Menu/Menu.types.ts +2 -2
  540. package/src/components/navigation/Menu/Menu.utils.ts +17 -17
  541. package/src/components/navigation/Menu/MenuItem.tsx +9 -11
  542. package/src/components/navigation/Menu/SubMenu.tsx +8 -6
  543. package/src/components/navigation/Menu/index.tsx +4 -69
  544. package/src/components/navigation/NavBar/NavBar.styles.ts +1 -1
  545. package/src/components/navigation/NavBar/NavBar.tsx +7 -10
  546. package/src/components/navigation/NavBar/NavBar.types.ts +3 -3
  547. package/src/components/navigation/NavBar/index.tsx +1 -1
  548. package/src/components/navigation/Pagination/Pagination.test.tsx +2 -3
  549. package/src/components/navigation/Pagination/Pagination.tsx +3 -3
  550. package/src/components/navigation/Pagination/Pagination.types.ts +3 -2
  551. package/src/components/navigation/Pagination/index.ts +9 -3
  552. package/src/components/navigation/Steps/Step.tsx +24 -44
  553. package/src/components/navigation/Steps/Steps.styles.ts +28 -13
  554. package/src/components/navigation/Steps/Steps.test.tsx +2 -0
  555. package/src/components/navigation/Steps/Steps.tsx +88 -89
  556. package/src/components/navigation/Steps/Steps.types.ts +30 -30
  557. package/src/components/navigation/Steps/index.tsx +1 -1
  558. package/src/components/navigation/Tabs/Tabs.test.tsx +3 -2
  559. package/src/components/navigation/Tabs/Tabs.types.ts +4 -3
  560. package/src/components/navigation/index.tsx +21 -16
  561. package/src/constants/index.ts +1 -1
  562. package/src/hooks/index.ts +52 -102
  563. package/src/hooks/types.ts +4 -5
  564. package/src/hooks/useAsync.ts +46 -47
  565. package/src/hooks/useClickOutside.ts +52 -0
  566. package/src/hooks/useCounter.ts +87 -0
  567. package/src/hooks/useDebounce.ts +150 -0
  568. package/src/hooks/useDeepCompareEffect.ts +88 -0
  569. package/src/hooks/useEventListener.ts +77 -0
  570. package/src/hooks/useMediaQuery.ts +75 -0
  571. package/src/hooks/useMutation.ts +233 -0
  572. package/src/hooks/usePerformance.ts +1 -64
  573. package/src/hooks/usePlatform.ts +3 -1
  574. package/src/hooks/usePrevious.ts +25 -0
  575. package/src/hooks/useRequest.ts +12 -7
  576. package/src/hooks/useStateManagement.ts +1 -1
  577. package/src/hooks/useStorage.ts +169 -0
  578. package/src/hooks/useStyle.ts +8 -2
  579. package/src/hooks/useToggle.ts +54 -0
  580. package/src/index.ts +34 -9
  581. package/src/theme/ThemeProvider.tsx +3 -7
  582. package/src/theme/ThemeProvider.types.ts +1 -1
  583. package/src/theme/defaults.ts +1 -1
  584. package/src/theme/design-system.ts +2 -2
  585. package/src/theme/design-tokens.ts +85 -99
  586. package/src/theme/generated/dark-theme.scss +1 -1
  587. package/src/theme/generated/tokens.scss +82 -18
  588. package/src/theme/index.ts +8 -29
  589. package/src/theme/responsive.tsx +36 -34
  590. package/src/theme/styles.ts +1 -1
  591. package/src/theme/useThemeUtils.ts +43 -43
  592. package/src/theme/utils.ts +32 -32
  593. package/src/theme/variables.ts +70 -51
  594. package/src/types/accessibility.ts +36 -37
  595. package/src/types/button.ts +25 -27
  596. package/src/types/component-props.ts +6 -1
  597. package/src/types/glob.d.ts +4 -0
  598. package/src/types/index.ts +2 -2
  599. package/src/types/standardized-components.ts +9 -3
  600. package/src/types/utils.ts +13 -23
  601. package/src/utils/__tests__/responsiveUtils.test.ts +5 -4
  602. package/src/utils/abort-controller.ts +48 -0
  603. package/src/utils/cache.ts +2 -6
  604. package/src/utils/createNamespace.ts +4 -4
  605. package/src/utils/environment.ts +26 -6
  606. package/src/utils/error-handler.ts +2 -2
  607. package/src/utils/errorLogger.ts +16 -20
  608. package/src/utils/formatUtils.ts +38 -70
  609. package/src/utils/http/error-codes.ts +314 -0
  610. package/src/utils/http/http-client.test.ts +63 -0
  611. package/src/utils/{network → http}/http-client.ts +45 -35
  612. package/src/utils/http/request-cache.ts +127 -0
  613. package/src/utils/http/request.ts +954 -0
  614. package/src/utils/http/taro-adapter.test.ts +74 -0
  615. package/src/utils/http/taro-adapter.ts +24 -0
  616. package/src/utils/http/types.ts +414 -0
  617. package/src/utils/http/web-adapter.ts +33 -0
  618. package/src/utils/index.ts +5 -8
  619. package/src/utils/inputValidator.ts +17 -14
  620. package/src/utils/performance/performance.ts +60 -71
  621. package/src/utils/responsiveUtils.ts +7 -16
  622. package/src/utils/rtl-support.ts +29 -19
  623. package/src/utils/security/api-security.ts +47 -39
  624. package/src/utils/securityHeaders.ts +61 -67
  625. package/src/utils/typeHelpers.ts +10 -10
  626. package/src/utils/types/dataProcessing.ts +93 -92
  627. package/src/utils/types/typeHelpers.ts +31 -21
  628. package/src/utils/xssProtection.ts +96 -48
  629. package/dist/js/index-6NJ3A1Dn.js.map +0 -1
  630. package/dist/js/index-DffLRSro.js.map +0 -1
  631. package/src/components/form/Input/Input.enhanced.tsx +0 -732
  632. package/src/components/navigation/Menu/__tests__/Menu.test.tsx +0 -687
  633. package/src/components/navigation/Tree/Tree.styles.ts +0 -553
  634. package/src/components/navigation/Tree/Tree.test.basic.tsx +0 -7
  635. package/src/components/navigation/Tree/Tree.test.functional.tsx +0 -496
  636. package/src/components/navigation/Tree/Tree.test.import.check.tsx +0 -6
  637. package/src/components/navigation/Tree/Tree.test.import.tsx +0 -6
  638. package/src/components/navigation/Tree/Tree.test.minimal.tsx +0 -5
  639. package/src/components/navigation/Tree/Tree.test.simple.tsx +0 -30
  640. package/src/components/navigation/Tree/Tree.test.tsx +0 -908
  641. package/src/components/navigation/Tree/Tree.test.working.tsx +0 -673
  642. package/src/components/navigation/Tree/Tree.tsx +0 -600
  643. package/src/components/navigation/Tree/Tree.types.ts +0 -909
  644. package/src/components/navigation/Tree/Tree.utils.ts +0 -452
  645. package/src/components/navigation/Tree/index.ts +0 -33
  646. package/src/components/navigation/Tree/index.tsx +0 -23
  647. package/src/utils/network/http-client.test.ts +0 -18
@@ -1,673 +0,0 @@
1
- import React from 'react'
2
- import { render, screen, fireEvent, act } from '@testing-library/react'
3
- import { vi } from 'vitest'
4
- import { Pagination } from '../Pagination'
5
- import type { PaginationRef } from '../Pagination.types'
6
-
7
- // Mock Taro components
8
- vi.mock('@tarojs/components', () => ({
9
- View: 'div',
10
- Text: 'span',
11
- Picker: ({ onChange, range, children, ...props }: { onChange?: (e: any) => void; range?: any[]; children?: React.ReactNode; [key: string]: any }) => {
12
- // The Pagination component uses rangeKey="label" but the data is just an array of numbers
13
- // We need to simulate the Picker's behavior properly
14
- return (
15
- <select {...props} role="combobox" onChange={(e) => {
16
- const selectedIndex = parseInt(e.target.value);
17
- // const selectedValue = range ? range[selectedIndex] : selectedIndex;
18
- onChange && onChange({ detail: { value: selectedIndex } });
19
- }}>
20
- {range?.map((value, index) => (
21
- <option key={index} value={index}>{value}</option>
22
- ))}
23
- {children}
24
- </select>
25
- );
26
- },
27
- select: ({ onChange, ...props }: { onChange?: (e: any) => void; [key: string]: any }) => {
28
- return <select {...props} onChange={(e) => onChange && onChange({ target: { value: parseInt(e.target.value) } })} />
29
- }
30
- }))
31
-
32
- // Mock the Input component from form module
33
- vi.mock('../../form/Input', () => ({
34
- Input: ({ onChange, onInput, value, ...props }: { onChange?: (e: any) => void; onInput?: (e: any) => void; value?: string; [key: string]: any }) => {
35
- // Taro Input uses onInput instead of onChange for value changes
36
- const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {
37
- const event = {
38
- detail: {
39
- value: e.target.value
40
- }
41
- }
42
- if (onInput) {
43
- onInput(event)
44
- }
45
- if (onChange) {
46
- onChange(event)
47
- }
48
- }
49
- return <input {...props} value={value} onChange={handleChange} />
50
- }
51
- }))
52
-
53
- // Mock styles
54
- vi.mock('../Pagination.styles', () => ({
55
- paginationStyles: {
56
- SIZE_MAP: {
57
- small: { padding: '4px 8px', fontSize: '12px' },
58
- default: { padding: '8px 12px', fontSize: '14px' },
59
- medium: { padding: '10px 14px', fontSize: '14px' },
60
- large: { padding: '12px 16px', fontSize: '16px' }
61
- },
62
- getBaseStyle: (props: any) => ({
63
- display: 'flex',
64
- alignItems: 'center',
65
- justifyContent: props.align === 'center' ? 'center' : props.align === 'left' ? 'flex-start' : 'flex-end',
66
- gap: '8px',
67
- padding: props.size === 'small' ? '4px' : props.size === 'large' ? '12px' : '8px'
68
- }),
69
- getButtonStyle: (props: any) => ({
70
- padding: props.size === 'small' ? '4px 8px' : props.size === 'large' ? '12px 16px' : '8px 12px',
71
- fontSize: props.size === 'small' ? '12px' : props.size === 'large' ? '16px' : '14px',
72
- opacity: props.disabled ? 0.5 : 1,
73
- cursor: props.disabled ? 'not-allowed' : 'pointer'
74
- }),
75
- getPageButtonStyle: (props: any) => ({
76
- padding: props.size === 'small' ? '4px 8px' : props.size === 'large' ? '12px 16px' : '8px 12px',
77
- fontSize: props.size === 'small' ? '12px' : props.size === 'large' ? '16px' : '14px',
78
- backgroundColor: props.active ? '#1890ff' : 'transparent',
79
- color: props.active ? 'white' : 'inherit',
80
- opacity: props.disabled ? 0.5 : 1,
81
- cursor: props.disabled ? 'not-allowed' : 'pointer'
82
- }),
83
- getJumpButtonStyle: (size: any) => ({
84
- padding: size === 'small' ? '4px 8px' : size === 'large' ? '12px 16px' : '8px 12px',
85
- fontSize: size === 'small' ? '12px' : size === 'large' ? '16px' : '14px',
86
- cursor: 'pointer'
87
- }),
88
- getTotalStyle: () => ({
89
- marginRight: '16px',
90
- fontSize: '14px',
91
- color: '#666'
92
- }),
93
- getQuickJumperStyle: () => ({
94
- display: 'flex',
95
- alignItems: 'center',
96
- gap: '8px'
97
- }),
98
- getInputStyle: () => ({
99
- width: '50px',
100
- padding: '4px 8px',
101
- border: '1px solid #d9d9d9',
102
- borderRadius: '4px'
103
- }),
104
- getSelectStyle: () => ({
105
- padding: '4px 8px',
106
- border: '1px solid #d9d9d9',
107
- borderRadius: '4px'
108
- }),
109
- getClassName: (props: any) => `taro-uno-pagination taro-uno-pagination--${props.size} taro-uno-pagination--${props.align} ${props.disabled ? 'taro-uno-pagination--disabled' : ''} ${props.simple ? 'taro-uno-pagination--simple' : ''} ${props.className || ''}`
110
- }
111
- }))
112
-
113
- describe('Pagination Component', () => {
114
- const mockRef = React.createRef<PaginationRef>()
115
-
116
- beforeEach(() => {
117
- vi.clearAllMocks()
118
- })
119
-
120
- describe('Rendering', () => {
121
- it('renders pagination with default props', () => {
122
- render(<Pagination total={100} data-testid="pagination" />)
123
- const pagination = screen.getByTestId('pagination')
124
- expect(pagination).toBeInTheDocument()
125
- })
126
-
127
- it('renders pagination with custom current page', () => {
128
- render(<Pagination total={100} current={3} data-testid="pagination" />)
129
- const pagination = screen.getByTestId('pagination')
130
- expect(pagination).toBeInTheDocument()
131
- })
132
-
133
- it('renders pagination with custom page size', () => {
134
- render(<Pagination total={100} pageSize={20} data-testid="pagination" />)
135
- const pagination = screen.getByTestId('pagination')
136
- expect(pagination).toBeInTheDocument()
137
- })
138
-
139
- it('renders pagination with custom size', () => {
140
- render(<Pagination total={100} size="small" data-testid="pagination" />)
141
- const pagination = screen.getByTestId('pagination')
142
- expect(pagination).toBeInTheDocument()
143
- })
144
-
145
- it('renders pagination with show total', () => {
146
- render(<Pagination total={100} showTotal data-testid="pagination" />)
147
- const pagination = screen.getByTestId('pagination')
148
- expect(pagination).toBeInTheDocument()
149
- })
150
-
151
- it('renders pagination with custom show total function', () => {
152
- const showTotal = (total: number, range: [number, number]) => `显示 ${range[0]}-${range[1]} 条,共 ${total} 条`
153
- render(<Pagination total={100} showTotal={showTotal} data-testid="pagination" />)
154
- const pagination = screen.getByTestId('pagination')
155
- expect(pagination).toBeInTheDocument()
156
- })
157
-
158
- it('renders pagination with quick jumper', () => {
159
- render(<Pagination total={100} showQuickJumper data-testid="pagination" />)
160
- const pagination = screen.getByTestId('pagination')
161
- expect(pagination).toBeInTheDocument()
162
- })
163
-
164
- it('renders pagination with size changer', () => {
165
- render(<Pagination total={100} showSizeChanger data-testid="pagination" />)
166
- const pagination = screen.getByTestId('pagination')
167
- expect(pagination).toBeInTheDocument()
168
- })
169
-
170
- it('renders pagination with disabled state', () => {
171
- render(<Pagination total={100} disabled data-testid="pagination" />)
172
- const pagination = screen.getByTestId('pagination')
173
- expect(pagination).toBeInTheDocument()
174
- })
175
-
176
- it('renders pagination in simple mode', () => {
177
- render(<Pagination total={100} simple data-testid="pagination" />)
178
- const pagination = screen.getByTestId('pagination')
179
- expect(pagination).toBeInTheDocument()
180
- })
181
-
182
- it('renders pagination with custom alignment', () => {
183
- render(<Pagination total={100} align="center" data-testid="pagination" />)
184
- const pagination = screen.getByTestId('pagination')
185
- expect(pagination).toBeInTheDocument()
186
- })
187
-
188
- it('renders pagination with custom position', () => {
189
- render(<Pagination total={100} position="top" data-testid="pagination" />)
190
- const pagination = screen.getByTestId('pagination')
191
- expect(pagination).toBeInTheDocument()
192
- })
193
-
194
- it('renders pagination with custom page size options', () => {
195
- render(<Pagination total={100} showSizeChanger pageSizeOptions={[10, 30, 50]} data-testid="pagination" />)
196
- const pagination = screen.getByTestId('pagination')
197
- expect(pagination).toBeInTheDocument()
198
- })
199
-
200
- it('renders pagination with custom className', () => {
201
- render(<Pagination total={100} className="custom-pagination" data-testid="pagination" />)
202
- const pagination = screen.getByTestId('pagination')
203
- expect(pagination).toBeInTheDocument()
204
- expect(pagination).toHaveClass('custom-pagination')
205
- })
206
-
207
- it('renders pagination with custom style', () => {
208
- const customStyle = { backgroundColor: '#f0f0f0', padding: '16px' }
209
- render(<Pagination total={100} style={customStyle} data-testid="pagination" />)
210
- const pagination = screen.getByTestId('pagination')
211
- expect(pagination).toBeInTheDocument()
212
- })
213
-
214
- it('renders pagination with item render function', () => {
215
- const itemRender = (page: number, type: string, element: React.ReactNode) => {
216
- if (type === 'page') {
217
- return <span data-testid={`page-${page}`}>[{page}]</span>
218
- }
219
- return element
220
- }
221
- render(<Pagination total={100} itemRender={itemRender} data-testid="pagination" />)
222
- const pagination = screen.getByTestId('pagination')
223
- expect(pagination).toBeInTheDocument()
224
- })
225
-
226
- it('handles empty total gracefully', () => {
227
- render(<Pagination total={0} data-testid="pagination" />)
228
- const pagination = screen.getByTestId('pagination')
229
- expect(pagination).toBeInTheDocument()
230
- })
231
-
232
- it('handles single page gracefully', () => {
233
- render(<Pagination total={5} pageSize={10} data-testid="pagination" />)
234
- const pagination = screen.getByTestId('pagination')
235
- expect(pagination).toBeInTheDocument()
236
- })
237
- })
238
-
239
- describe('Page Navigation', () => {
240
- it('navigates to next page', () => {
241
- const handleChange = vi.fn()
242
- render(<Pagination total={100} onChange={handleChange} data-testid="pagination" />)
243
-
244
- const nextButton = screen.getByText('下一页')
245
- fireEvent.click(nextButton)
246
-
247
- expect(handleChange).toHaveBeenCalledWith(2, 10)
248
- })
249
-
250
- it('navigates to previous page', () => {
251
- const handleChange = vi.fn()
252
- render(<Pagination total={100} current={3} onChange={handleChange} data-testid="pagination" />)
253
-
254
- const prevButton = screen.getByText('上一页')
255
- fireEvent.click(prevButton)
256
-
257
- expect(handleChange).toHaveBeenCalledWith(2, 10)
258
- })
259
-
260
- it('navigates to specific page', () => {
261
- const handleChange = vi.fn()
262
- render(<Pagination total={100} onChange={handleChange} data-testid="pagination" />)
263
-
264
- const pageButton = screen.getByText('3')
265
- fireEvent.click(pageButton)
266
-
267
- expect(handleChange).toHaveBeenCalledWith(3, 10)
268
- })
269
-
270
- it('navigates using jump buttons', () => {
271
- const handleChange = vi.fn()
272
- render(<Pagination total={100} current={10} onChange={handleChange} data-testid="pagination" />)
273
-
274
- const jumpButton = screen.getByText('...')
275
- fireEvent.click(jumpButton)
276
-
277
- expect(handleChange).toHaveBeenCalledWith(5, 10)
278
- })
279
-
280
- it('does not navigate when disabled', () => {
281
- const handleChange = vi.fn()
282
- render(<Pagination total={100} disabled onChange={handleChange} data-testid="pagination" />)
283
-
284
- const nextButton = screen.getByText('下一页')
285
- fireEvent.click(nextButton)
286
-
287
- expect(handleChange).not.toHaveBeenCalled()
288
- })
289
-
290
- it('does not navigate prev on first page', () => {
291
- const handleChange = vi.fn()
292
- render(<Pagination total={100} current={1} onChange={handleChange} data-testid="pagination" />)
293
-
294
- const prevButton = screen.getByText('上一页')
295
- fireEvent.click(prevButton)
296
-
297
- expect(handleChange).not.toHaveBeenCalled()
298
- })
299
-
300
- it('does not navigate next on last page', () => {
301
- const handleChange = vi.fn()
302
- render(<Pagination total={100} current={10} onChange={handleChange} data-testid="pagination" />)
303
-
304
- const nextButton = screen.getByText('下一页')
305
- fireEvent.click(nextButton)
306
-
307
- expect(handleChange).not.toHaveBeenCalled()
308
- })
309
- })
310
-
311
- describe('Page Size Changes', () => {
312
- it('changes page size', () => {
313
- const handleSizeChange = vi.fn()
314
- const handleChange = vi.fn()
315
- render(
316
- <Pagination
317
- total={100}
318
- showSizeChanger
319
- onShowSizeChange={handleSizeChange}
320
- onChange={handleChange}
321
- data-testid="pagination"
322
- />
323
- )
324
-
325
- const select = screen.getByRole('combobox')
326
- fireEvent.change(select, { target: { value: '1' } }) // Index 1 = 20 items per page
327
-
328
- expect(handleSizeChange).toHaveBeenCalledWith(1, 20)
329
- expect(handleChange).toHaveBeenCalledWith(1, 20)
330
- })
331
-
332
- it('adjusts current page when changing page size', () => {
333
- const handleSizeChange = vi.fn()
334
- const handleChange = vi.fn()
335
- render(
336
- <Pagination
337
- total={100}
338
- current={8}
339
- showSizeChanger
340
- onShowSizeChange={handleSizeChange}
341
- onChange={handleChange}
342
- data-testid="pagination"
343
- />
344
- )
345
-
346
- const select = screen.getByRole('combobox')
347
- fireEvent.change(select, { target: { value: '1' } }) // Index 1 = 20 items per page
348
-
349
- expect(handleSizeChange).toHaveBeenCalledWith(5, 20)
350
- expect(handleChange).toHaveBeenCalledWith(5, 20)
351
- })
352
- })
353
-
354
- describe('Quick Jumper', () => {
355
- it('jumps to specific page', () => {
356
- const handleChange = vi.fn()
357
- render(<Pagination total={100} showQuickJumper onChange={handleChange} data-testid="pagination" />)
358
-
359
- const input = screen.getByRole('spinbutton')
360
- fireEvent.change(input, { target: { value: '5' } })
361
-
362
- const jumpButton = screen.getByText('确定')
363
- fireEvent.click(jumpButton)
364
-
365
- expect(handleChange).toHaveBeenCalledWith(5, 10)
366
- })
367
-
368
- it('does not jump with invalid page number', () => {
369
- const handleChange = vi.fn()
370
- render(<Pagination total={100} showQuickJumper onChange={handleChange} data-testid="pagination" />)
371
-
372
- const input = screen.getByRole('spinbutton')
373
- fireEvent.change(input, { target: { value: 'invalid' } })
374
-
375
- const jumpButton = screen.getByText('确定')
376
- fireEvent.click(jumpButton)
377
-
378
- expect(handleChange).not.toHaveBeenCalled()
379
- })
380
-
381
- it('does not jump with out of range page number', () => {
382
- const handleChange = vi.fn()
383
- render(<Pagination total={100} showQuickJumper onChange={handleChange} data-testid="pagination" />)
384
-
385
- const input = screen.getByRole('spinbutton')
386
- fireEvent.change(input, { target: { value: '999' } })
387
-
388
- const jumpButton = screen.getByText('确定')
389
- fireEvent.click(jumpButton)
390
-
391
- expect(handleChange).not.toHaveBeenCalled()
392
- })
393
- })
394
-
395
- describe('Props Updates', () => {
396
- it('updates current page correctly', () => {
397
- const { rerender } = render(<Pagination total={100} current={2} data-testid="pagination" />)
398
- const pagination = screen.getByTestId('pagination')
399
- rerender(<Pagination total={100} current={5} data-testid="pagination" />)
400
- expect(pagination).toBeInTheDocument()
401
- })
402
-
403
- it('updates page size correctly', () => {
404
- const { rerender } = render(<Pagination total={100} pageSize={10} data-testid="pagination" />)
405
- const pagination = screen.getByTestId('pagination')
406
- rerender(<Pagination total={100} pageSize={20} data-testid="pagination" />)
407
- expect(pagination).toBeInTheDocument()
408
- })
409
-
410
- it('updates total correctly', () => {
411
- const { rerender } = render(<Pagination total={100} data-testid="pagination" />)
412
- const pagination = screen.getByTestId('pagination')
413
- rerender(<Pagination total={200} data-testid="pagination" />)
414
- expect(pagination).toBeInTheDocument()
415
- })
416
-
417
- it('updates disabled state correctly', () => {
418
- const { rerender } = render(<Pagination total={100} disabled={false} data-testid="pagination" />)
419
- const pagination = screen.getByTestId('pagination')
420
- rerender(<Pagination total={100} disabled={true} data-testid="pagination" />)
421
- expect(pagination).toBeInTheDocument()
422
- })
423
-
424
- it('updates size correctly', () => {
425
- const { rerender } = render(<Pagination total={100} size="default" data-testid="pagination" />)
426
- const pagination = screen.getByTestId('pagination')
427
- rerender(<Pagination total={100} size="small" data-testid="pagination" />)
428
- expect(pagination).toBeInTheDocument()
429
- })
430
- })
431
-
432
- describe('Ref API', () => {
433
- it('exposes ref methods correctly', () => {
434
- render(<Pagination total={100} ref={mockRef} data-testid="pagination" />)
435
-
436
- act(() => {
437
- expect(mockRef.current).toBeDefined()
438
- expect(mockRef.current?.getCurrent()).toBe(1)
439
- expect(mockRef.current?.getPageSize()).toBe(10)
440
- expect(mockRef.current?.getTotalPages()).toBe(10)
441
- expect(mockRef.current?.getTotal()).toBe(100)
442
- })
443
- })
444
-
445
- it('sets current page via ref method', () => {
446
- render(<Pagination total={100} defaultCurrent={1} ref={mockRef} data-testid="pagination" />)
447
-
448
- act(() => {
449
- if (mockRef.current) {
450
- expect(() => mockRef.current.setCurrent(5)).not.toThrow()
451
- }
452
- })
453
- })
454
-
455
- it('sets page size via ref method', () => {
456
- render(<Pagination total={100} defaultPageSize={10} ref={mockRef} data-testid="pagination" />)
457
-
458
- act(() => {
459
- if (mockRef.current) {
460
- expect(() => mockRef.current.setPageSize(20)).not.toThrow()
461
- }
462
- })
463
- })
464
-
465
- it('navigates via ref methods', () => {
466
- const handleChange = vi.fn()
467
- render(<Pagination total={100} defaultCurrent={1} onChange={handleChange} ref={mockRef} data-testid="pagination" />)
468
-
469
- act(() => {
470
- if (mockRef.current) {
471
- mockRef.current.next()
472
- expect(handleChange).toHaveBeenCalled()
473
-
474
- mockRef.current.prev()
475
- expect(handleChange).toHaveBeenCalled()
476
-
477
- mockRef.current.goTo(5)
478
- expect(handleChange).toHaveBeenCalled()
479
-
480
- mockRef.current.first()
481
- expect(handleChange).toHaveBeenCalled()
482
-
483
- mockRef.current.last()
484
- expect(handleChange).toHaveBeenCalled()
485
- }
486
- })
487
- })
488
-
489
- it('provides element access via ref', () => {
490
- render(<Pagination total={100} ref={mockRef} data-testid="pagination" />)
491
-
492
- act(() => {
493
- expect(mockRef.current?.element).toBeDefined()
494
- })
495
- })
496
- })
497
-
498
- describe('Controlled vs Uncontrolled', () => {
499
- it('works in controlled mode', () => {
500
- const handleChange = vi.fn()
501
- render(<Pagination total={100} current={3} onChange={handleChange} data-testid="pagination" />)
502
-
503
- const nextButton = screen.getByText('下一页')
504
- fireEvent.click(nextButton)
505
-
506
- expect(handleChange).toHaveBeenCalledWith(4, 10)
507
- })
508
-
509
- it('works in uncontrolled mode', () => {
510
- const handleChange = vi.fn()
511
- render(<Pagination total={100} defaultCurrent={3} onChange={handleChange} data-testid="pagination" />)
512
-
513
- const nextButton = screen.getByText('下一页')
514
- fireEvent.click(nextButton)
515
-
516
- expect(handleChange).toHaveBeenCalledWith(4, 10)
517
- })
518
-
519
- it('handles controlled page size', () => {
520
- const handleSizeChange = vi.fn()
521
- render(<Pagination total={100} pageSize={20} showSizeChanger onShowSizeChange={handleSizeChange} data-testid="pagination" />)
522
-
523
- const select = screen.getByRole('combobox')
524
- fireEvent.change(select, { target: { value: '2' } }) // Index 2 = 50 items per page
525
-
526
- expect(handleSizeChange).toHaveBeenCalled()
527
- })
528
-
529
- it('handles uncontrolled page size', () => {
530
- const handleSizeChange = vi.fn()
531
- render(<Pagination total={100} defaultPageSize={20} showSizeChanger onShowSizeChange={handleSizeChange} data-testid="pagination" />)
532
-
533
- const select = screen.getByRole('combobox')
534
- fireEvent.change(select, { target: { value: '2' } }) // Index 2 = 50 items per page
535
-
536
- expect(handleSizeChange).toHaveBeenCalled()
537
- })
538
- })
539
-
540
- describe('Accessibility', () => {
541
- it('has proper role attribute', () => {
542
- render(<Pagination total={100} data-testid="pagination" />)
543
- const pagination = screen.getByTestId('pagination')
544
- expect(pagination).toBeInTheDocument()
545
- })
546
-
547
- it('supports aria-label', () => {
548
- render(<Pagination total={100} aria-label="Pagination navigation" data-testid="pagination" />)
549
- const pagination = screen.getByTestId('pagination')
550
- expect(pagination).toHaveAttribute('aria-label', 'Pagination navigation')
551
- })
552
-
553
- it('supports aria-labelledby', () => {
554
- render(<Pagination total={100} aria-labelledby="pagination-title" data-testid="pagination" />)
555
- const pagination = screen.getByTestId('pagination')
556
- expect(pagination).toHaveAttribute('aria-labelledby', 'pagination-title')
557
- })
558
-
559
- it('supports data attributes', () => {
560
- render(<Pagination total={100} data-testid="pagination" data-custom="value" />)
561
- const pagination = screen.getByTestId('pagination')
562
- expect(pagination).toHaveAttribute('data-custom', 'value')
563
- })
564
- })
565
-
566
- describe('Edge Cases', () => {
567
- it('handles negative total gracefully', () => {
568
- render(<Pagination total={-100} data-testid="pagination" />)
569
- const pagination = screen.getByTestId('pagination')
570
- expect(pagination).toBeInTheDocument()
571
- })
572
-
573
- it('handles zero page size gracefully', () => {
574
- render(<Pagination total={100} pageSize={0} data-testid="pagination" />)
575
- const pagination = screen.getByTestId('pagination')
576
- expect(pagination).toBeInTheDocument()
577
- })
578
-
579
- it('handles negative page size gracefully', () => {
580
- render(<Pagination total={100} pageSize={-10} data-testid="pagination" />)
581
- const pagination = screen.getByTestId('pagination')
582
- expect(pagination).toBeInTheDocument()
583
- })
584
-
585
- it('handles current page out of range', () => {
586
- render(<Pagination total={100} current={999} data-testid="pagination" />)
587
- const pagination = screen.getByTestId('pagination')
588
- expect(pagination).toBeInTheDocument()
589
- })
590
-
591
- it('handles negative current page gracefully', () => {
592
- render(<Pagination total={100} current={-5} data-testid="pagination" />)
593
- const pagination = screen.getByTestId('pagination')
594
- expect(pagination).toBeInTheDocument()
595
- })
596
-
597
- it('handles very large total', () => {
598
- render(<Pagination total={999999} data-testid="pagination" />)
599
- const pagination = screen.getByTestId('pagination')
600
- expect(pagination).toBeInTheDocument()
601
- })
602
-
603
- it('handles very small page size', () => {
604
- render(<Pagination total={100} pageSize={1} data-testid="pagination" />)
605
- const pagination = screen.getByTestId('pagination')
606
- expect(pagination).toBeInTheDocument()
607
- })
608
-
609
- it('handles empty pageSizeOptions', () => {
610
- render(<Pagination total={100} showSizeChanger pageSizeOptions={[]} data-testid="pagination" />)
611
- const pagination = screen.getByTestId('pagination')
612
- expect(pagination).toBeInTheDocument()
613
- })
614
- })
615
-
616
- describe('Performance', () => {
617
- it('renders efficiently with many pages', () => {
618
- render(<Pagination total={10000} pageSize={10} data-testid="pagination" />)
619
- const pagination = screen.getByTestId('pagination')
620
- expect(pagination).toBeInTheDocument()
621
- })
622
-
623
- it('handles frequent prop updates efficiently', () => {
624
- const { rerender } = render(<Pagination total={100} current={1} data-testid="pagination" />)
625
-
626
- for (let i = 0; i < 10; i++) {
627
- rerender(<Pagination total={100} current={i + 1} data-testid="pagination" />)
628
- }
629
-
630
- expect(screen.getByTestId('pagination')).toBeInTheDocument()
631
- })
632
- })
633
-
634
- describe('Simple Mode', () => {
635
- it('renders in simple mode correctly', () => {
636
- render(<Pagination total={100} simple data-testid="pagination" />)
637
- const pagination = screen.getByTestId('pagination')
638
- expect(pagination).toBeInTheDocument()
639
-
640
- // Should show current page info
641
- expect(screen.getByText('1 / 10')).toBeInTheDocument()
642
- })
643
-
644
- it('navigates in simple mode', () => {
645
- const handleChange = vi.fn()
646
- render(<Pagination total={100} simple onChange={handleChange} data-testid="pagination" />)
647
-
648
- const nextButton = screen.getByText('下一页')
649
- fireEvent.click(nextButton)
650
-
651
- expect(handleChange).toHaveBeenCalledWith(2, 10)
652
- })
653
-
654
- it('shows correct page info in simple mode', () => {
655
- render(<Pagination total={100} current={5} simple data-testid="pagination" />)
656
- expect(screen.getByText('5 / 10')).toBeInTheDocument()
657
- })
658
- })
659
-
660
- describe('Show More/Less Items', () => {
661
- it('handles showMore prop', () => {
662
- render(<Pagination total={100} showMore={false} data-testid="pagination" />)
663
- const pagination = screen.getByTestId('pagination')
664
- expect(pagination).toBeInTheDocument()
665
- })
666
-
667
- it('handles showLessItems prop', () => {
668
- render(<Pagination total={100} showLessItems={true} data-testid="pagination" />)
669
- const pagination = screen.getByTestId('pagination')
670
- expect(pagination).toBeInTheDocument()
671
- })
672
- })
673
- })