taro-uno-ui 1.0.1 → 1.0.2

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 (414) hide show
  1. package/README.md +67 -30
  2. package/dist/js/{index-CDFsvu80.js → index-QpKiGsEQ.js} +39026 -28023
  3. package/dist/js/index-QpKiGsEQ.js.map +1 -0
  4. package/dist/js/{index-JffnTUrv.js → index-nnTHNhwl.js} +38743 -27720
  5. package/dist/js/index-nnTHNhwl.js.map +1 -0
  6. package/package.json +4 -4
  7. package/dist/js/index-CDFsvu80.js.map +0 -1
  8. package/dist/js/index-DFdcksbe.js +0 -1165
  9. package/dist/js/index-DFdcksbe.js.map +0 -1
  10. package/dist/js/index-DXRIkWX1.js +0 -1148
  11. package/dist/js/index-DXRIkWX1.js.map +0 -1
  12. package/dist/js/index-JffnTUrv.js.map +0 -1
  13. package/dist/utils/http/request.d.ts +0 -280
  14. package/src/app.config.ts +0 -55
  15. package/src/app.scss +0 -508
  16. package/src/app.tsx +0 -44
  17. package/src/components/basic/Button/Button.styles.ts +0 -130
  18. package/src/components/basic/Button/Button.test.tsx +0 -154
  19. package/src/components/basic/Button/Button.tsx +0 -133
  20. package/src/components/basic/Button/Button.types.ts +0 -81
  21. package/src/components/basic/Button/index.tsx +0 -6
  22. package/src/components/basic/Divider/Divider.styles.ts +0 -488
  23. package/src/components/basic/Divider/Divider.test.tsx +0 -551
  24. package/src/components/basic/Divider/Divider.tsx +0 -392
  25. package/src/components/basic/Divider/Divider.types.ts +0 -261
  26. package/src/components/basic/Divider/index.tsx +0 -25
  27. package/src/components/basic/Icon/Icon.data.ts +0 -474
  28. package/src/components/basic/Icon/Icon.styles.ts +0 -359
  29. package/src/components/basic/Icon/Icon.test.tsx +0 -357
  30. package/src/components/basic/Icon/Icon.tsx +0 -167
  31. package/src/components/basic/Icon/Icon.types.ts +0 -210
  32. package/src/components/basic/Icon/IconManager.ts +0 -229
  33. package/src/components/basic/Icon/index.tsx +0 -22
  34. package/src/components/basic/Text/Text.styles.ts +0 -500
  35. package/src/components/basic/Text/Text.test.tsx +0 -299
  36. package/src/components/basic/Text/Text.tsx +0 -340
  37. package/src/components/basic/Text/Text.types.ts +0 -329
  38. package/src/components/basic/Text/index.tsx +0 -27
  39. package/src/components/basic/Typography/Typography.styles.ts +0 -347
  40. package/src/components/basic/Typography/Typography.tsx +0 -207
  41. package/src/components/basic/Typography/Typography.types.ts +0 -296
  42. package/src/components/basic/Typography/index.tsx +0 -14
  43. package/src/components/basic/Video/Video.styles.ts +0 -777
  44. package/src/components/basic/Video/Video.test.tsx +0 -490
  45. package/src/components/basic/Video/Video.tsx +0 -1468
  46. package/src/components/basic/Video/Video.types.ts +0 -500
  47. package/src/components/basic/Video/index.tsx +0 -26
  48. package/src/components/basic/index.tsx +0 -300
  49. package/src/components/common/ErrorBoundary.tsx +0 -87
  50. package/src/components/common/LazyComponent.tsx +0 -247
  51. package/src/components/common/ResponsiveContainer.tsx +0 -93
  52. package/src/components/common/ResponsiveGrid.tsx +0 -183
  53. package/src/components/common/SecurityProvider.tsx +0 -98
  54. package/src/components/common/ThemeProvider.tsx +0 -115
  55. package/src/components/common/VirtualList.tsx +0 -350
  56. package/src/components/common/__tests__/ErrorBoundary.test.tsx +0 -249
  57. package/src/components/common/index.tsx +0 -32
  58. package/src/components/display/Avatar/Avatar.styles.ts +0 -62
  59. package/src/components/display/Avatar/Avatar.test.tsx +0 -390
  60. package/src/components/display/Avatar/Avatar.tsx +0 -66
  61. package/src/components/display/Avatar/Avatar.types.ts +0 -40
  62. package/src/components/display/Avatar/index.ts +0 -3
  63. package/src/components/display/Badge/Badge.tsx +0 -29
  64. package/src/components/display/Badge/Badge.types.ts +0 -29
  65. package/src/components/display/Badge/index.ts +0 -2
  66. package/src/components/display/Calendar/Calendar.styles.ts +0 -255
  67. package/src/components/display/Calendar/Calendar.test.tsx +0 -42
  68. package/src/components/display/Calendar/Calendar.tsx +0 -358
  69. package/src/components/display/Calendar/Calendar.types.ts +0 -91
  70. package/src/components/display/Calendar/index.ts +0 -3
  71. package/src/components/display/Card/Card.styles.ts +0 -89
  72. package/src/components/display/Card/Card.test.tsx +0 -182
  73. package/src/components/display/Card/Card.tsx +0 -135
  74. package/src/components/display/Card/Card.types.ts +0 -55
  75. package/src/components/display/Card/index.ts +0 -3
  76. package/src/components/display/Carousel/Carousel.styles.ts +0 -206
  77. package/src/components/display/Carousel/Carousel.tsx +0 -290
  78. package/src/components/display/Carousel/Carousel.types.ts +0 -57
  79. package/src/components/display/Carousel/index.ts +0 -3
  80. package/src/components/display/List/List.styles.ts +0 -79
  81. package/src/components/display/List/List.tsx +0 -114
  82. package/src/components/display/List/List.types.ts +0 -68
  83. package/src/components/display/List/index.ts +0 -3
  84. package/src/components/display/Rate/Rate.styles.ts +0 -254
  85. package/src/components/display/Rate/Rate.tsx +0 -324
  86. package/src/components/display/Rate/Rate.types.ts +0 -112
  87. package/src/components/display/Rate/index.ts +0 -20
  88. package/src/components/display/Table/Table.styles.ts +0 -269
  89. package/src/components/display/Table/Table.test.tsx +0 -345
  90. package/src/components/display/Table/Table.tsx +0 -426
  91. package/src/components/display/Table/Table.types.ts +0 -256
  92. package/src/components/display/Table/index.tsx +0 -16
  93. package/src/components/display/Tag/Tag.styles.ts +0 -197
  94. package/src/components/display/Tag/Tag.test.tsx +0 -541
  95. package/src/components/display/Tag/Tag.tsx +0 -139
  96. package/src/components/display/Tag/Tag.types.ts +0 -49
  97. package/src/components/display/Tag/index.ts +0 -3
  98. package/src/components/display/Timeline/Timeline.styles.ts +0 -211
  99. package/src/components/display/Timeline/Timeline.tsx +0 -220
  100. package/src/components/display/Timeline/Timeline.types.ts +0 -56
  101. package/src/components/display/Timeline/index.ts +0 -3
  102. package/src/components/display/index.tsx +0 -147
  103. package/src/components/feedback/Loading/Loading.styles.ts +0 -117
  104. package/src/components/feedback/Loading/Loading.test.tsx +0 -534
  105. package/src/components/feedback/Loading/Loading.tsx +0 -132
  106. package/src/components/feedback/Loading/Loading.types.ts +0 -33
  107. package/src/components/feedback/Loading/index.ts +0 -6
  108. package/src/components/feedback/Message/Message.styles.ts +0 -41
  109. package/src/components/feedback/Message/Message.test.tsx +0 -234
  110. package/src/components/feedback/Message/Message.tsx +0 -96
  111. package/src/components/feedback/Message/Message.types.ts +0 -37
  112. package/src/components/feedback/Message/index.ts +0 -6
  113. package/src/components/feedback/Modal/Modal.styles.ts +0 -21
  114. package/src/components/feedback/Modal/Modal.test.tsx +0 -11
  115. package/src/components/feedback/Modal/Modal.tsx +0 -269
  116. package/src/components/feedback/Modal/Modal.types.ts +0 -151
  117. package/src/components/feedback/Modal/index.tsx +0 -11
  118. package/src/components/feedback/Notification/Notification.styles.ts +0 -453
  119. package/src/components/feedback/Notification/Notification.test.tsx +0 -401
  120. package/src/components/feedback/Notification/Notification.tsx +0 -347
  121. package/src/components/feedback/Notification/Notification.types.ts +0 -339
  122. package/src/components/feedback/Notification/NotificationManager.tsx +0 -405
  123. package/src/components/feedback/Notification/index.ts +0 -40
  124. package/src/components/feedback/Notification/index.tsx +0 -154
  125. package/src/components/feedback/Progress/Progress.styles.ts +0 -469
  126. package/src/components/feedback/Progress/Progress.test.simple.tsx +0 -14
  127. package/src/components/feedback/Progress/Progress.test.tsx +0 -312
  128. package/src/components/feedback/Progress/Progress.tsx +0 -488
  129. package/src/components/feedback/Progress/Progress.types.ts +0 -163
  130. package/src/components/feedback/Progress/index.ts +0 -3
  131. package/src/components/feedback/Progress/index.tsx +0 -38
  132. package/src/components/feedback/Progress/utils/animation.ts +0 -193
  133. package/src/components/feedback/Progress/utils/index.ts +0 -26
  134. package/src/components/feedback/Progress/utils/progress-calculator.ts +0 -199
  135. package/src/components/feedback/Result/Result.styles.ts +0 -139
  136. package/src/components/feedback/Result/Result.tsx +0 -221
  137. package/src/components/feedback/Result/Result.types.ts +0 -128
  138. package/src/components/feedback/Result/index.tsx +0 -3
  139. package/src/components/feedback/Toast/Toast.styles.ts +0 -17
  140. package/src/components/feedback/Toast/Toast.test.tsx +0 -10
  141. package/src/components/feedback/Toast/Toast.tsx +0 -384
  142. package/src/components/feedback/Toast/Toast.types.ts +0 -86
  143. package/src/components/feedback/Toast/index.tsx +0 -3
  144. package/src/components/feedback/Tooltip/Tooltip.examples.tsx +0 -435
  145. package/src/components/feedback/Tooltip/Tooltip.styles.ts +0 -340
  146. package/src/components/feedback/Tooltip/Tooltip.test.tsx +0 -446
  147. package/src/components/feedback/Tooltip/Tooltip.tsx +0 -302
  148. package/src/components/feedback/Tooltip/Tooltip.types.ts +0 -166
  149. package/src/components/feedback/Tooltip/index.ts +0 -3
  150. package/src/components/feedback/Tooltip/index.tsx +0 -246
  151. package/src/components/feedback/index.tsx +0 -176
  152. package/src/components/form/Cascader/Cascader.styles.ts +0 -526
  153. package/src/components/form/Cascader/Cascader.test.tsx +0 -77
  154. package/src/components/form/Cascader/Cascader.tsx +0 -581
  155. package/src/components/form/Cascader/Cascader.types.ts +0 -581
  156. package/src/components/form/Cascader/hooks/index.ts +0 -3
  157. package/src/components/form/Cascader/hooks/useCascaderFieldNames.ts +0 -19
  158. package/src/components/form/Cascader/hooks/useCascaderOptions.ts +0 -127
  159. package/src/components/form/Cascader/hooks/useCascaderState.ts +0 -139
  160. package/src/components/form/Cascader/index.ts +0 -25
  161. package/src/components/form/Cascader/utils/formatDisplayValue.ts +0 -19
  162. package/src/components/form/Cascader/utils/index.ts +0 -1
  163. package/src/components/form/Checkbox/Checkbox.styles.ts +0 -607
  164. package/src/components/form/Checkbox/Checkbox.test.tsx +0 -1140
  165. package/src/components/form/Checkbox/Checkbox.tsx +0 -489
  166. package/src/components/form/Checkbox/Checkbox.types.ts +0 -472
  167. package/src/components/form/Checkbox/CheckboxGroup.tsx +0 -444
  168. package/src/components/form/Checkbox/index.tsx +0 -27
  169. package/src/components/form/DatePicker/DatePicker.styles.ts +0 -393
  170. package/src/components/form/DatePicker/DatePicker.test.tsx +0 -407
  171. package/src/components/form/DatePicker/DatePicker.tsx +0 -376
  172. package/src/components/form/DatePicker/DatePicker.types.ts +0 -250
  173. package/src/components/form/DatePicker/index.tsx +0 -15
  174. package/src/components/form/Form/Form.styles.ts +0 -357
  175. package/src/components/form/Form/Form.test.tsx +0 -122
  176. package/src/components/form/Form/Form.tsx +0 -257
  177. package/src/components/form/Form/Form.types.ts +0 -422
  178. package/src/components/form/Form/index.tsx +0 -31
  179. package/src/components/form/Form/useFormLogic.ts +0 -497
  180. package/src/components/form/Input/Input.styles.ts +0 -445
  181. package/src/components/form/Input/Input.test.tsx +0 -494
  182. package/src/components/form/Input/Input.tsx +0 -305
  183. package/src/components/form/Input/Input.types.ts +0 -297
  184. package/src/components/form/Input/index.tsx +0 -26
  185. package/src/components/form/Input/useInputLogic.test.ts +0 -82
  186. package/src/components/form/Input/useInputLogic.ts +0 -260
  187. package/src/components/form/InputNumber/InputNumber.styles.ts +0 -716
  188. package/src/components/form/InputNumber/InputNumber.tsx +0 -402
  189. package/src/components/form/InputNumber/InputNumber.types.ts +0 -336
  190. package/src/components/form/InputNumber/components/InputNumberClearButton.tsx +0 -24
  191. package/src/components/form/InputNumber/components/InputNumberControls.tsx +0 -33
  192. package/src/components/form/InputNumber/components/index.ts +0 -2
  193. package/src/components/form/InputNumber/hooks/index.ts +0 -4
  194. package/src/components/form/InputNumber/hooks/useInputNumberState.ts +0 -313
  195. package/src/components/form/InputNumber/hooks/useInputNumberValidation.ts +0 -148
  196. package/src/components/form/InputNumber/index.ts +0 -25
  197. package/src/components/form/Radio/Radio.styles.ts +0 -451
  198. package/src/components/form/Radio/Radio.test.tsx +0 -547
  199. package/src/components/form/Radio/Radio.tsx +0 -277
  200. package/src/components/form/Radio/Radio.types.ts +0 -414
  201. package/src/components/form/Radio/index.tsx +0 -21
  202. package/src/components/form/Select/Select.styles.ts +0 -518
  203. package/src/components/form/Select/Select.test.tsx +0 -648
  204. package/src/components/form/Select/Select.tsx +0 -474
  205. package/src/components/form/Select/Select.types.ts +0 -429
  206. package/src/components/form/Select/index.tsx +0 -30
  207. package/src/components/form/Slider/Slider.styles.ts +0 -139
  208. package/src/components/form/Slider/Slider.test.tsx +0 -553
  209. package/src/components/form/Slider/Slider.tsx +0 -312
  210. package/src/components/form/Slider/Slider.types.ts +0 -110
  211. package/src/components/form/Slider/index.tsx +0 -3
  212. package/src/components/form/Switch/Switch.styles.ts +0 -534
  213. package/src/components/form/Switch/Switch.test.tsx +0 -345
  214. package/src/components/form/Switch/Switch.tsx +0 -458
  215. package/src/components/form/Switch/Switch.types.ts +0 -386
  216. package/src/components/form/Switch/index.tsx +0 -26
  217. package/src/components/form/Textarea/Textarea.styles.ts +0 -592
  218. package/src/components/form/Textarea/Textarea.test.tsx +0 -1075
  219. package/src/components/form/Textarea/Textarea.tsx +0 -608
  220. package/src/components/form/Textarea/Textarea.types.ts +0 -374
  221. package/src/components/form/Textarea/index.tsx +0 -26
  222. package/src/components/form/TimePicker/TimePicker.styles.ts +0 -434
  223. package/src/components/form/TimePicker/TimePicker.test.tsx +0 -306
  224. package/src/components/form/TimePicker/TimePicker.tsx +0 -250
  225. package/src/components/form/TimePicker/TimePicker.types.ts +0 -385
  226. package/src/components/form/TimePicker/index.ts +0 -21
  227. package/src/components/form/Transfer/Transfer.styles.ts +0 -490
  228. package/src/components/form/Transfer/Transfer.test.tsx +0 -316
  229. package/src/components/form/Transfer/Transfer.tsx +0 -414
  230. package/src/components/form/Transfer/Transfer.types.ts +0 -565
  231. package/src/components/form/Transfer/components/TransferItem.tsx +0 -94
  232. package/src/components/form/Transfer/components/TransferList.tsx +0 -298
  233. package/src/components/form/Transfer/components/TransferOperations.tsx +0 -81
  234. package/src/components/form/Transfer/components/TransferPagination.tsx +0 -139
  235. package/src/components/form/Transfer/components/TransferSearch.tsx +0 -85
  236. package/src/components/form/Transfer/components/index.ts +0 -6
  237. package/src/components/form/Transfer/hooks/index.ts +0 -3
  238. package/src/components/form/Transfer/hooks/useTransferData.ts +0 -202
  239. package/src/components/form/Transfer/hooks/useTransferState.ts +0 -120
  240. package/src/components/form/Transfer/index.ts +0 -27
  241. package/src/components/form/Upload/Upload.styles.ts +0 -145
  242. package/src/components/form/Upload/Upload.test.tsx +0 -10
  243. package/src/components/form/Upload/Upload.tsx +0 -498
  244. package/src/components/form/Upload/Upload.types.ts +0 -200
  245. package/src/components/form/Upload/index.tsx +0 -12
  246. package/src/components/form/index.tsx +0 -152
  247. package/src/components/index.tsx +0 -145
  248. package/src/components/layout/Affix/Affix.styles.ts +0 -42
  249. package/src/components/layout/Affix/Affix.test.tsx +0 -10
  250. package/src/components/layout/Affix/Affix.tsx +0 -83
  251. package/src/components/layout/Affix/Affix.types.ts +0 -29
  252. package/src/components/layout/Affix/index.tsx +0 -3
  253. package/src/components/layout/Col/Col.styles.ts +0 -185
  254. package/src/components/layout/Col/Col.test.tsx +0 -537
  255. package/src/components/layout/Col/Col.tsx +0 -97
  256. package/src/components/layout/Col/Col.types.ts +0 -59
  257. package/src/components/layout/Col/index.tsx +0 -3
  258. package/src/components/layout/Container/Container.styles.ts +0 -163
  259. package/src/components/layout/Container/Container.test.tsx +0 -380
  260. package/src/components/layout/Container/Container.tsx +0 -123
  261. package/src/components/layout/Container/Container.types.ts +0 -63
  262. package/src/components/layout/Container/index.tsx +0 -3
  263. package/src/components/layout/Grid/Grid.styles.ts +0 -183
  264. package/src/components/layout/Grid/Grid.test.tsx +0 -637
  265. package/src/components/layout/Grid/Grid.tsx +0 -123
  266. package/src/components/layout/Grid/Grid.types.ts +0 -78
  267. package/src/components/layout/Grid/index.tsx +0 -3
  268. package/src/components/layout/Layout/Content.tsx +0 -30
  269. package/src/components/layout/Layout/Footer.tsx +0 -30
  270. package/src/components/layout/Layout/Header.tsx +0 -30
  271. package/src/components/layout/Layout/Layout.styles.ts +0 -84
  272. package/src/components/layout/Layout/Layout.test.tsx +0 -10
  273. package/src/components/layout/Layout/Layout.tsx +0 -28
  274. package/src/components/layout/Layout/Layout.types.ts +0 -58
  275. package/src/components/layout/Layout/Sider.tsx +0 -44
  276. package/src/components/layout/Layout/index.tsx +0 -22
  277. package/src/components/layout/Row/Row.styles.ts +0 -159
  278. package/src/components/layout/Row/Row.test.tsx +0 -467
  279. package/src/components/layout/Row/Row.tsx +0 -111
  280. package/src/components/layout/Row/Row.types.ts +0 -60
  281. package/src/components/layout/Row/index.tsx +0 -3
  282. package/src/components/layout/Space/Space.styles.ts +0 -255
  283. package/src/components/layout/Space/Space.test.tsx +0 -682
  284. package/src/components/layout/Space/Space.tsx +0 -203
  285. package/src/components/layout/Space/Space.types.ts +0 -92
  286. package/src/components/layout/Space/index.tsx +0 -12
  287. package/src/components/layout/index.tsx +0 -78
  288. package/src/components/navigation/Menu/Menu.constants.ts +0 -69
  289. package/src/components/navigation/Menu/Menu.stories.tsx +0 -107
  290. package/src/components/navigation/Menu/Menu.styles.ts +0 -767
  291. package/src/components/navigation/Menu/Menu.tsx +0 -352
  292. package/src/components/navigation/Menu/Menu.types.ts +0 -231
  293. package/src/components/navigation/Menu/Menu.utils.ts +0 -187
  294. package/src/components/navigation/Menu/MenuItem.tsx +0 -124
  295. package/src/components/navigation/Menu/SubMenu.tsx +0 -150
  296. package/src/components/navigation/Menu/index.tsx +0 -59
  297. package/src/components/navigation/NavBar/NavBar.styles.ts +0 -129
  298. package/src/components/navigation/NavBar/NavBar.test.tsx +0 -287
  299. package/src/components/navigation/NavBar/NavBar.tsx +0 -228
  300. package/src/components/navigation/NavBar/NavBar.types.ts +0 -54
  301. package/src/components/navigation/NavBar/index.tsx +0 -3
  302. package/src/components/navigation/Pagination/Pagination.styles.ts +0 -187
  303. package/src/components/navigation/Pagination/Pagination.test.tsx +0 -672
  304. package/src/components/navigation/Pagination/Pagination.tsx +0 -395
  305. package/src/components/navigation/Pagination/Pagination.types.ts +0 -87
  306. package/src/components/navigation/Pagination/index.ts +0 -24
  307. package/src/components/navigation/Pagination/index.tsx +0 -9
  308. package/src/components/navigation/Steps/Step.tsx +0 -36
  309. package/src/components/navigation/Steps/Steps.styles.ts +0 -169
  310. package/src/components/navigation/Steps/Steps.test.tsx +0 -14
  311. package/src/components/navigation/Steps/Steps.tsx +0 -112
  312. package/src/components/navigation/Steps/Steps.types.ts +0 -47
  313. package/src/components/navigation/Steps/index.tsx +0 -3
  314. package/src/components/navigation/Tabs/Tabs.styles.ts +0 -199
  315. package/src/components/navigation/Tabs/Tabs.test.tsx +0 -662
  316. package/src/components/navigation/Tabs/Tabs.tsx +0 -253
  317. package/src/components/navigation/Tabs/Tabs.types.ts +0 -115
  318. package/src/components/navigation/Tabs/index.tsx +0 -3
  319. package/src/components/navigation/index.tsx +0 -88
  320. package/src/constants/index.ts +0 -785
  321. package/src/hooks/index.ts +0 -60
  322. package/src/hooks/types.ts +0 -9
  323. package/src/hooks/useAsync.ts +0 -64
  324. package/src/hooks/useClickOutside.ts +0 -52
  325. package/src/hooks/useCounter.ts +0 -87
  326. package/src/hooks/useDebounce.ts +0 -150
  327. package/src/hooks/useDeepCompareEffect.ts +0 -88
  328. package/src/hooks/useEventHandling.ts +0 -444
  329. package/src/hooks/useEventListener.ts +0 -77
  330. package/src/hooks/useLifecycle.ts +0 -399
  331. package/src/hooks/useMediaQuery.ts +0 -75
  332. package/src/hooks/useMutation.ts +0 -233
  333. package/src/hooks/usePerformance.ts +0 -378
  334. package/src/hooks/usePerformanceMonitor.ts +0 -348
  335. package/src/hooks/usePlatform.ts +0 -64
  336. package/src/hooks/usePrevious.ts +0 -25
  337. package/src/hooks/useRequest.test.ts +0 -11
  338. package/src/hooks/useRequest.ts +0 -140
  339. package/src/hooks/useStateManagement.ts +0 -300
  340. package/src/hooks/useStorage.ts +0 -169
  341. package/src/hooks/useStyle.ts +0 -543
  342. package/src/hooks/useTheme.ts +0 -347
  343. package/src/hooks/useToggle.ts +0 -54
  344. package/src/hooks/useVirtualScroll.ts +0 -331
  345. package/src/index.ts +0 -323
  346. package/src/platform/index.ts +0 -1188
  347. package/src/providers/AppProvider.test.tsx +0 -63
  348. package/src/providers/AppProvider.tsx +0 -155
  349. package/src/providers/index.ts +0 -1
  350. package/src/theme/ThemeProvider.tsx +0 -279
  351. package/src/theme/ThemeProvider.types.ts +0 -26
  352. package/src/theme/animations.tsx +0 -660
  353. package/src/theme/defaults.ts +0 -188
  354. package/src/theme/design-system.ts +0 -562
  355. package/src/theme/design-tokens.ts +0 -1122
  356. package/src/theme/generated/dark-theme.scss +0 -120
  357. package/src/theme/generated/tokens.css +0 -441
  358. package/src/theme/generated/tokens.scss +0 -384
  359. package/src/theme/index.ts +0 -99
  360. package/src/theme/responsive.tsx +0 -195
  361. package/src/theme/styles/mixins.scss +0 -612
  362. package/src/theme/styles/variables.scss +0 -295
  363. package/src/theme/styles.ts +0 -403
  364. package/src/theme/tokens/colors.ts +0 -256
  365. package/src/theme/tokens/effects.ts +0 -260
  366. package/src/theme/tokens/index.ts +0 -217
  367. package/src/theme/tokens/spacing.ts +0 -137
  368. package/src/theme/tokens/typography.ts +0 -186
  369. package/src/theme/types.ts +0 -188
  370. package/src/theme/useThemeUtils.ts +0 -313
  371. package/src/theme/utils.ts +0 -501
  372. package/src/theme/variables.ts +0 -602
  373. package/src/types/accessibility.ts +0 -50
  374. package/src/types/button.ts +0 -560
  375. package/src/types/component-props.ts +0 -322
  376. package/src/types/env.d.ts +0 -20
  377. package/src/types/glob.d.ts +0 -4
  378. package/src/types/index.ts +0 -427
  379. package/src/types/modules.d.ts +0 -40
  380. package/src/types/standardized-components.ts +0 -550
  381. package/src/types/taro-adapter.d.ts +0 -174
  382. package/src/types/taro-components.d.ts +0 -73
  383. package/src/types/utils.ts +0 -400
  384. package/src/utils/__tests__/inputValidator.test.ts +0 -338
  385. package/src/utils/__tests__/responsiveUtils.test.ts +0 -311
  386. package/src/utils/__tests__/xssProtection.test.ts +0 -268
  387. package/src/utils/abort-controller.ts +0 -48
  388. package/src/utils/cache.ts +0 -79
  389. package/src/utils/createNamespace.ts +0 -24
  390. package/src/utils/environment.ts +0 -115
  391. package/src/utils/error-handler.ts +0 -88
  392. package/src/utils/errorLogger.ts +0 -193
  393. package/src/utils/formatUtils.ts +0 -412
  394. package/src/utils/http/error-codes.ts +0 -314
  395. package/src/utils/http/http-client.test.ts +0 -63
  396. package/src/utils/http/http-client.ts +0 -161
  397. package/src/utils/http/request-cache.ts +0 -127
  398. package/src/utils/http/request.ts +0 -954
  399. package/src/utils/http/taro-adapter.test.ts +0 -74
  400. package/src/utils/http/taro-adapter.ts +0 -24
  401. package/src/utils/http/types.ts +0 -414
  402. package/src/utils/http/web-adapter.ts +0 -33
  403. package/src/utils/index.ts +0 -112
  404. package/src/utils/inputValidator.ts +0 -264
  405. package/src/utils/performance/performance.ts +0 -839
  406. package/src/utils/responsiveUtils.ts +0 -348
  407. package/src/utils/rtl-support.ts +0 -354
  408. package/src/utils/security/api-security.ts +0 -394
  409. package/src/utils/security/xss-protection.ts +0 -69
  410. package/src/utils/securityHeaders.ts +0 -308
  411. package/src/utils/typeHelpers.ts +0 -16
  412. package/src/utils/types/dataProcessing.ts +0 -544
  413. package/src/utils/types/typeHelpers.ts +0 -197
  414. package/src/utils/xssProtection.ts +0 -468
@@ -1,384 +0,0 @@
1
- /**
2
- * 设计令牌 SCSS 变量
3
- * 自动生成,请勿手动修改
4
- * 生成时间: 2025-11-13T09:32:00.008Z
5
- */
6
-
7
- // ==================== 颜色令牌 ====================
8
- $colors-primary-50: #f0f9ff;
9
- $colors-primary-100: #e0f2fe;
10
- $colors-primary-200: #bae6fd;
11
- $colors-primary-300: #7dd3fc;
12
- $colors-primary-400: #38bdf8;
13
- $colors-primary-500: #0ea5e9;
14
- $colors-primary-600: #0284c7;
15
- $colors-primary-700: #0369a1;
16
- $colors-primary-800: #075985;
17
- $colors-primary-900: #0c4a6e;
18
- $colors-primary-950: #082f49;
19
- $colors-secondary-50: #fafafa;
20
- $colors-secondary-100: #f4f4f5;
21
- $colors-secondary-200: #e4e4e7;
22
- $colors-secondary-300: #d4d4d8;
23
- $colors-secondary-400: #a1a1aa;
24
- $colors-secondary-500: #71717a;
25
- $colors-secondary-600: #52525b;
26
- $colors-secondary-700: #3f3f46;
27
- $colors-secondary-800: #27272a;
28
- $colors-secondary-900: #18181b;
29
- $colors-secondary-950: #09090b;
30
- $colors-success-50: #f0fdf4;
31
- $colors-success-100: #dcfce7;
32
- $colors-success-200: #bbf7d0;
33
- $colors-success-300: #86efac;
34
- $colors-success-400: #4ade80;
35
- $colors-success-500: #22c55e;
36
- $colors-success-600: #16a34a;
37
- $colors-success-700: #15803d;
38
- $colors-success-800: #166534;
39
- $colors-success-900: #14532d;
40
- $colors-success-950: #052e16;
41
- $colors-warning-50: #fffbeb;
42
- $colors-warning-100: #fef3c7;
43
- $colors-warning-200: #fde68a;
44
- $colors-warning-300: #fcd34d;
45
- $colors-warning-400: #fbbf24;
46
- $colors-warning-500: #f59e0b;
47
- $colors-warning-600: #d97706;
48
- $colors-warning-700: #b45309;
49
- $colors-warning-800: #92400e;
50
- $colors-warning-900: #78350f;
51
- $colors-warning-950: #451a03;
52
- $colors-error-50: #fef2f2;
53
- $colors-error-100: #fee2e2;
54
- $colors-error-200: #fecaca;
55
- $colors-error-300: #fca5a5;
56
- $colors-error-400: #f87171;
57
- $colors-error-500: #ef4444;
58
- $colors-error-600: #dc2626;
59
- $colors-error-700: #b91c1c;
60
- $colors-error-800: #991b1b;
61
- $colors-error-900: #7f1d1d;
62
- $colors-error-950: #450a0a;
63
- $colors-info-50: #eff6ff;
64
- $colors-info-100: #dbeafe;
65
- $colors-info-200: #bfdbfe;
66
- $colors-info-300: #93c5fd;
67
- $colors-info-400: #60a5fa;
68
- $colors-info-500: #3b82f6;
69
- $colors-info-600: #2563eb;
70
- $colors-info-700: #1d4ed8;
71
- $colors-info-800: #1e40af;
72
- $colors-info-900: #1e3a8a;
73
- $colors-info-950: #172554;
74
- $colors-neutral-50: #fafafa;
75
- $colors-neutral-100: #f4f4f5;
76
- $colors-neutral-200: #e4e4e7;
77
- $colors-neutral-300: #d4d4d8;
78
- $colors-neutral-400: #a1a1aa;
79
- $colors-neutral-500: #71717a;
80
- $colors-neutral-600: #52525b;
81
- $colors-neutral-700: #3f3f46;
82
- $colors-neutral-800: #27272a;
83
- $colors-neutral-900: #18181b;
84
- $colors-neutral-950: #09090b;
85
- $colors-text-primary: #111827;
86
- $colors-text-secondary: #6b7280;
87
- $colors-text-tertiary: #4b5563;
88
- $colors-text-disabled: #9ca3af;
89
- $colors-text-inverse: #ffffff;
90
- $colors-text-link: #0ea5e9;
91
- $colors-text-placeholder: #9ca3af;
92
- $colors-background-primary: #ffffff;
93
- $colors-background-secondary: #f9fafb;
94
- $colors-background-tertiary: #f3f4f6;
95
- $colors-background-card: #ffffff;
96
- $colors-background-input: #f9fafb;
97
- $colors-background-mask: rgba(0, 0, 0, 0.5);
98
- $colors-background-hover: #f9fafb;
99
- $colors-background-active: #f3f4f6;
100
- $colors-border-default: #e5e7eb;
101
- $colors-border-light: #f3f4f6;
102
- $colors-border-focus: #0ea5e9;
103
- $colors-border-error: #ef4444;
104
- $colors-border-success: #22c55e;
105
- $colors-border-warning: #f59e0b;
106
- $colors-shadow-default: rgba(0, 0, 0, 0.1);
107
- $colors-shadow-light: rgba(0, 0, 0, 0.05);
108
- $colors-shadow-medium: rgba(0, 0, 0, 0.15);
109
- $colors-shadow-dark: rgba(0, 0, 0, 0.25);
110
- $colors-shadow-colored: rgba(14, 165, 233, 0.15);
111
- $colors-status-online: #22c55e;
112
- $colors-status-offline: #6b7280;
113
- $colors-status-busy: #ef4444;
114
- $colors-status-away: #f59e0b;
115
- $colors-interactive-hover: rgba(0, 0, 0, 0.05);
116
- $colors-interactive-active: rgba(0, 0, 0, 0.1);
117
- $colors-interactive-focus: rgba(59, 130, 246, 0.1);
118
- $colors-interactive-selected: rgba(59, 130, 246, 0.2);
119
- $colors-interactive-disabled: rgba(0, 0, 0, 0.3);
120
-
121
- // ==================== 间距令牌 ====================
122
- $spacing-0: 0;
123
- $spacing-1: 4px;
124
- $spacing-2: 8px;
125
- $spacing-3: 12px;
126
- $spacing-4: 16px;
127
- $spacing-5: 20px;
128
- $spacing-6: 24px;
129
- $spacing-7: 28px;
130
- $spacing-8: 32px;
131
- $spacing-9: 36px;
132
- $spacing-10: 40px;
133
- $spacing-11: 44px;
134
- $spacing-12: 48px;
135
- $spacing-14: 56px;
136
- $spacing-16: 64px;
137
- $spacing-18: 72px;
138
- $spacing-20: 80px;
139
- $spacing-24: 96px;
140
- $spacing-28: 112px;
141
- $spacing-32: 128px;
142
- $spacing-36: 144px;
143
- $spacing-40: 160px;
144
- $spacing-44: 176px;
145
- $spacing-48: 192px;
146
- $spacing-52: 208px;
147
- $spacing-56: 224px;
148
- $spacing-60: 240px;
149
- $spacing-64: 256px;
150
- $spacing-72: 288px;
151
- $spacing-80: 320px;
152
- $spacing-96: 384px;
153
- $spacing-px: 1px;
154
- $spacing-0.5: 2px;
155
- $spacing-1.5: 6px;
156
- $spacing-2.5: 10px;
157
- $spacing-3.5: 14px;
158
- $spacing-component-xs: 8px;
159
- $spacing-component-sm: 12px;
160
- $spacing-component-md: 16px;
161
- $spacing-component-lg: 24px;
162
- $spacing-component-xl: 32px;
163
- $spacing-component-2xl: 48px;
164
- $spacing-layout-sm: 16px;
165
- $spacing-layout-md: 24px;
166
- $spacing-layout-lg: 32px;
167
- $spacing-layout-xl: 48px;
168
- $spacing-layout-2xl: 64px;
169
- $spacing-container-sm: 640px;
170
- $spacing-container-md: 768px;
171
- $spacing-container-lg: 1024px;
172
- $spacing-container-xl: 1280px;
173
- $spacing-container-2xl: 1536px;
174
-
175
- // ==================== 字体令牌 ====================
176
- $typography-fontFamily-sans:
177
- Inter,
178
- -apple-system,
179
- BlinkMacSystemFont,
180
- Segoe UI,
181
- Roboto,
182
- Helvetica Neue,
183
- Arial,
184
- sans-serif;
185
- $typography-fontFamily-serif:
186
- Georgia,
187
- Cambria,
188
- Times New Roman,
189
- Times,
190
- serif;
191
- $typography-fontFamily-mono:
192
- Fira Code,
193
- Menlo,
194
- Monaco,
195
- Consolas,
196
- Liberation Mono,
197
- Courier New,
198
- monospace;
199
- $typography-fontFamily-display:
200
- Inter,
201
- -apple-system,
202
- BlinkMacSystemFont,
203
- Segoe UI,
204
- Roboto,
205
- Helvetica Neue,
206
- Arial,
207
- sans-serif;
208
- $typography-fontFamily-body:
209
- Inter,
210
- -apple-system,
211
- BlinkMacSystemFont,
212
- Segoe UI,
213
- Roboto,
214
- Helvetica Neue,
215
- Arial,
216
- sans-serif;
217
- $typography-fontSize-3xs: 10px;
218
- $typography-fontSize-2xs: 12px;
219
- $typography-fontSize-xs: 14px;
220
- $typography-fontSize-sm: 16px;
221
- $typography-fontSize-base: 18px;
222
- $typography-fontSize-lg: 20px;
223
- $typography-fontSize-xl: 24px;
224
- $typography-fontSize-2xl: 30px;
225
- $typography-fontSize-3xl: 36px;
226
- $typography-fontSize-4xl: 48px;
227
- $typography-fontSize-5xl: 60px;
228
- $typography-fontSize-6xl: 72px;
229
- $typography-fontSize-7xl: 96px;
230
- $typography-fontSize-8xl: 128px;
231
- $typography-fontSize-9xl: 160px;
232
- $typography-fontWeight-thin: 100;
233
- $typography-fontWeight-extralight: 200;
234
- $typography-fontWeight-light: 300;
235
- $typography-fontWeight-normal: 400;
236
- $typography-fontWeight-medium: 500;
237
- $typography-fontWeight-semibold: 600;
238
- $typography-fontWeight-bold: 700;
239
- $typography-fontWeight-extrabold: 800;
240
- $typography-fontWeight-black: 900;
241
- $typography-lineHeight-3: 1.75;
242
- $typography-lineHeight-4: 2;
243
- $typography-lineHeight-5: 2.25;
244
- $typography-lineHeight-6: 2.5;
245
- $typography-lineHeight-7: 2.75;
246
- $typography-lineHeight-8: 3;
247
- $typography-lineHeight-9: 3.25;
248
- $typography-lineHeight-10: 3.5;
249
- $typography-lineHeight-none: 1;
250
- $typography-lineHeight-tight: 1.25;
251
- $typography-lineHeight-snug: 1.375;
252
- $typography-lineHeight-normal: 1.5;
253
- $typography-lineHeight-relaxed: 1.625;
254
- $typography-lineHeight-loose: 2;
255
- $typography-letterSpacing-tighter: -0.05em;
256
- $typography-letterSpacing-tight: -0.025em;
257
- $typography-letterSpacing-normal: 0;
258
- $typography-letterSpacing-wide: 0.025em;
259
- $typography-letterSpacing-wider: 0.05em;
260
- $typography-letterSpacing-widest: 0.1em;
261
- $typography-paragraphSpacing-none: 0;
262
- $typography-paragraphSpacing-tight: 0.5rem;
263
- $typography-paragraphSpacing-normal: 1rem;
264
- $typography-paragraphSpacing-relaxed: 1.5rem;
265
- $typography-paragraphSpacing-loose: 2rem;
266
-
267
- // ==================== 效果令牌 ====================
268
- $effects-borderRadius-none: 0;
269
- $effects-borderRadius-xs: 2px;
270
- $effects-borderRadius-sm: 4px;
271
- $effects-borderRadius-md: 8px;
272
- $effects-borderRadius-lg: 12px;
273
- $effects-borderRadius-xl: 16px;
274
- $effects-borderRadius-2xl: 20px;
275
- $effects-borderRadius-3xl: 24px;
276
- $effects-borderRadius-full: 9999px;
277
- $effects-borderRadius-button-sm: 6px;
278
- $effects-borderRadius-button-md: 8px;
279
- $effects-borderRadius-button-lg: 12px;
280
- $effects-borderRadius-button-xl: 16px;
281
- $effects-borderRadius-input-sm: 6px;
282
- $effects-borderRadius-input-md: 8px;
283
- $effects-borderRadius-input-lg: 12px;
284
- $effects-borderRadius-card-sm: 8px;
285
- $effects-borderRadius-card-md: 12px;
286
- $effects-borderRadius-card-lg: 16px;
287
- $effects-borderRadius-modal: 12px;
288
- $effects-borderRadius-dropdown: 8px;
289
- $effects-boxShadow-none: none;
290
- $effects-boxShadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
291
- $effects-boxShadow-sm:
292
- 0 1px 3px 0 rgba(0, 0, 0, 0.1),
293
- 0 1px 2px 0 rgba(0, 0, 0, 0.06);
294
- $effects-boxShadow-md:
295
- 0 4px 6px -1px rgba(0, 0, 0, 0.1),
296
- 0 2px 4px -1px rgba(0, 0, 0, 0.06);
297
- $effects-boxShadow-lg:
298
- 0 10px 15px -3px rgba(0, 0, 0, 0.1),
299
- 0 4px 6px -2px rgba(0, 0, 0, 0.05);
300
- $effects-boxShadow-xl:
301
- 0 20px 25px -5px rgba(0, 0, 0, 0.1),
302
- 0 10px 10px -5px rgba(0, 0, 0, 0.04);
303
- $effects-boxShadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
304
- $effects-boxShadow-3xl: 0 35px 60px -15px rgba(0, 0, 0, 0.3);
305
- $effects-boxShadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, 0.06);
306
- $effects-boxShadow-colored: 0 10px 15px -3px rgba(14, 165, 233, 0.15);
307
- $effects-boxShadow-button-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
308
- $effects-boxShadow-button-md:
309
- 0 4px 6px -1px rgba(0, 0, 0, 0.1),
310
- 0 2px 4px -1px rgba(0, 0, 0, 0.06);
311
- $effects-boxShadow-button-lg:
312
- 0 10px 15px -3px rgba(0, 0, 0, 0.1),
313
- 0 4px 6px -2px rgba(0, 0, 0, 0.05);
314
- $effects-boxShadow-card-sm:
315
- 0 1px 3px 0 rgba(0, 0, 0, 0.1),
316
- 0 1px 2px 0 rgba(0, 0, 0, 0.06);
317
- $effects-boxShadow-card-md:
318
- 0 4px 6px -1px rgba(0, 0, 0, 0.1),
319
- 0 2px 4px -1px rgba(0, 0, 0, 0.06);
320
- $effects-boxShadow-card-lg:
321
- 0 10px 15px -3px rgba(0, 0, 0, 0.1),
322
- 0 4px 6px -2px rgba(0, 0, 0, 0.05);
323
- $effects-boxShadow-modal: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
324
- $effects-boxShadow-tooltip:
325
- 0 10px 15px -3px rgba(0, 0, 0, 0.1),
326
- 0 4px 6px -2px rgba(0, 0, 0, 0.05);
327
- $effects-boxShadow-dropdown:
328
- 0 10px 15px -3px rgba(0, 0, 0, 0.1),
329
- 0 4px 6px -2px rgba(0, 0, 0, 0.05);
330
- $effects-animation-duration-75: 75ms;
331
- $effects-animation-duration-100: 100ms;
332
- $effects-animation-duration-150: 150ms;
333
- $effects-animation-duration-200: 200ms;
334
- $effects-animation-duration-300: 300ms;
335
- $effects-animation-duration-500: 500ms;
336
- $effects-animation-duration-700: 700ms;
337
- $effects-animation-duration-1000: 1000ms;
338
- $effects-animation-easing-linear: linear;
339
- $effects-animation-easing-ease: ease;
340
- $effects-animation-easing-easeIn: ease-in;
341
- $effects-animation-easing-easeOut: ease-out;
342
- $effects-animation-easing-easeInOut: ease-in-out;
343
- $effects-animation-easing-in-quad: cubic-bezier(0.55, 0.055, 0.675, 0.19);
344
- $effects-animation-easing-in-cubic: cubic-bezier(0.55, 0.055, 0.675, 0.19);
345
- $effects-animation-easing-out-quad: cubic-bezier(0.25, 0.46, 0.45, 0.94);
346
- $effects-animation-easing-out-cubic: cubic-bezier(0.215, 0.61, 0.355, 1);
347
- $effects-animation-easing-in-out-quad: cubic-bezier(0.455, 0.03, 0.515, 0.955);
348
- $effects-animation-easing-in-out-cubic: cubic-bezier(0.645, 0.045, 0.355, 1);
349
- $effects-animation-delay-75: 75ms;
350
- $effects-animation-delay-100: 100ms;
351
- $effects-animation-delay-150: 150ms;
352
- $effects-animation-delay-200: 200ms;
353
- $effects-animation-delay-300: 300ms;
354
- $effects-animation-delay-500: 500ms;
355
- $effects-transition-none: none;
356
- $effects-transition-all: all 150ms ease-in-out;
357
- $effects-transition-common:
358
- color 150ms ease-in-out,
359
- background-color 150ms ease-in-out,
360
- border-color 150ms ease-in-out;
361
- $effects-transition-colors:
362
- color 150ms ease-in-out,
363
- background-color 150ms ease-in-out,
364
- border-color 150ms ease-in-out;
365
- $effects-transition-opacity: opacity 150ms ease-in-out;
366
- $effects-transition-shadow: box-shadow 150ms ease-in-out;
367
- $effects-transition-transform: transform 150ms ease-in-out;
368
- $effects-transition-button: all 150ms ease-in-out;
369
- $effects-transition-input: all 150ms ease-in-out;
370
- $effects-transition-modal: all 300ms ease-in-out;
371
- $effects-transition-tooltip: all 150ms ease-in-out;
372
- $effects-transition-dropdown: all 150ms ease-in-out;
373
- $effects-zIndex-hide: -1;
374
- $effects-zIndex-auto: auto;
375
- $effects-zIndex-base: 0;
376
- $effects-zIndex-dropdown: 1000;
377
- $effects-zIndex-sticky: 1020;
378
- $effects-zIndex-fixed: 1030;
379
- $effects-zIndex-modal-backdrop: 1040;
380
- $effects-zIndex-modal: 1050;
381
- $effects-zIndex-popover-backdrop: 1060;
382
- $effects-zIndex-popover: 1070;
383
- $effects-zIndex-tooltip: 1080;
384
- $effects-zIndex-max: 9999;
@@ -1,99 +0,0 @@
1
- /**
2
- * Taro-Uno UI 设计系统
3
- * 提供完整的设计令牌、主题管理、无障碍访问、响应式设计和动画系统
4
- */
5
-
6
- // 导入需要的模块
7
- import { defaultTheme, darkTheme } from './defaults';
8
- import { ColorUtils, ResponsiveUtils, ThemeValidator, ThemePresets } from './utils';
9
- import { createCSSVariables, generateCSSVariablesString } from './variables';
10
- import { createStyleUtils, generateStyles, createStyles } from './styles';
11
- import type { ThemeProvider, useTheme } from './ThemeProvider.types';
12
-
13
- // 导出类型定义
14
- export type {
15
- ThemeMode,
16
- ThemeConfig,
17
- ThemeColors,
18
- ThemeSpacing,
19
- ThemeTypography,
20
- ThemeBorderRadius,
21
- ThemeShadow,
22
- ThemeAnimation,
23
- } from './types';
24
-
25
- // 导出默认主题配置
26
- export { defaultTheme, darkTheme } from './defaults';
27
-
28
- // 导出工具函数
29
- export { default as themeUtils, ColorUtils, ResponsiveUtils, ThemeValidator, ThemePresets } from './utils';
30
-
31
- // 导出CSS变量系统
32
- export { default as CSSVariableGenerator, createCSSVariables, generateCSSVariablesString } from './variables';
33
- export type { CSSVariables, VariableInheritance, VariableGroup } from './variables';
34
-
35
- // 导出样式工具
36
- export { default as createStyleUtils, generateStyles, createStyles, styleUtils } from './styles';
37
- export type { StyleUtils as StyleUtilsType } from './styles';
38
-
39
- // 导出设计令牌系统
40
- export {
41
- default as DesignTokenGenerator,
42
- createDesignTokens,
43
- generateDesignTokenCSS,
44
- generateDarkThemeCSS,
45
- } from './design-tokens';
46
- export type { DesignTokens } from './design-tokens';
47
-
48
- // 导出ThemeProvider
49
- export { ThemeProvider, useTheme };
50
-
51
- // 主题快捷导出
52
- export * from './types';
53
- export * from './defaults';
54
- export * from './utils';
55
- export * from './variables';
56
- export * from './styles';
57
- export * from './design-tokens';
58
-
59
- // 主题预设
60
- export const themes = {
61
- default: defaultTheme,
62
- dark: darkTheme,
63
- };
64
-
65
- // 主题工具函数集合
66
- export const themeTools = {
67
- // 颜色工具
68
- color: ColorUtils,
69
-
70
- // 响应式工具
71
- responsive: ResponsiveUtils,
72
-
73
- // 验证工具
74
- validator: ThemeValidator,
75
-
76
- // 预设主题
77
- presets: ThemePresets,
78
-
79
- // CSS变量生成
80
- css: {
81
- createVariables: createCSSVariables,
82
- generateString: generateCSSVariablesString,
83
- },
84
-
85
- // 样式工具
86
- styles: {
87
- createUtils: createStyleUtils,
88
- generateStyles: generateStyles,
89
- createStyles: createStyles,
90
- },
91
- };
92
-
93
- // 默认导出
94
- export default {
95
- themes,
96
- themeTools,
97
- defaultTheme,
98
- darkTheme,
99
- };
@@ -1,195 +0,0 @@
1
- import { createContext, useContext, useState, useEffect, useCallback } from 'react';
2
-
3
- /**
4
- * 断点配置
5
- */
6
- export const breakpoints = {
7
- xs: 0,
8
- sm: 640,
9
- md: 768,
10
- lg: 1024,
11
- xl: 1280,
12
- '2xl': 1536,
13
- };
14
-
15
- /**
16
- * 断点顺序
17
- */
18
- const breakpointOrder = ['xs', 'sm', 'md', 'lg', 'xl', '2xl'] as const;
19
-
20
- /**
21
- * 屏幕尺寸类型
22
- */
23
- export interface ScreenSize {
24
- width: number;
25
- height: number;
26
- }
27
-
28
- /**
29
- * 响应式上下文类型
30
- */
31
- interface ResponsiveContextType {
32
- screenSize: ScreenSize;
33
- currentBreakpoint: keyof typeof breakpoints;
34
- isMobile: boolean;
35
- isTablet: boolean;
36
- isDesktop: boolean;
37
- matches: (breakpoint: keyof typeof breakpoints) => boolean;
38
- matchesMinWidth: (width: number) => boolean;
39
- matchesMaxWidth: (width: number) => boolean;
40
- getResponsiveValue: <T>(values: Partial<Record<string, T>>, defaultValue: T) => T;
41
- }
42
-
43
- /**
44
- * 响应式上下文
45
- */
46
- const ResponsiveContext = createContext<ResponsiveContextType | undefined>(undefined);
47
-
48
- /**
49
- * 响应式提供者组件
50
- */
51
- export function ResponsiveProvider({ children }: { children: React.ReactNode }) {
52
- const [screenSize, setScreenSize] = useState<ScreenSize>({
53
- width: typeof window !== 'undefined' ? window.innerWidth : 1024,
54
- height: typeof window !== 'undefined' ? window.innerHeight : 768,
55
- });
56
-
57
- // 更新屏幕尺寸
58
- useEffect(() => {
59
- if (typeof window === 'undefined') return;
60
-
61
- const handleResize = () => {
62
- setScreenSize({
63
- width: window.innerWidth,
64
- height: window.innerHeight,
65
- });
66
- };
67
-
68
- window.addEventListener('resize', handleResize);
69
- return () => window.removeEventListener('resize', handleResize);
70
- }, []);
71
-
72
- // 获取当前断点
73
- const getCurrentBreakpoint = useCallback(() => {
74
- const width = screenSize.width;
75
- let currentBreakpoint: keyof typeof breakpoints = 'xs';
76
-
77
- for (const [key, value] of Object.entries(breakpoints)) {
78
- if (width >= value) {
79
- currentBreakpoint = key as keyof typeof breakpoints;
80
- }
81
- }
82
-
83
- return currentBreakpoint;
84
- }, [screenSize.width]);
85
-
86
- const currentBreakpoint = getCurrentBreakpoint();
87
-
88
- // 响应式判断
89
- const isMobile = screenSize.width < breakpoints.md;
90
- const isTablet = screenSize.width >= breakpoints.md && screenSize.width < breakpoints.lg;
91
- const isDesktop = screenSize.width >= breakpoints.lg;
92
-
93
- // 断点匹配检查
94
- const matches = useCallback(
95
- (breakpoint: keyof typeof breakpoints) => {
96
- return screenSize.width >= breakpoints[breakpoint];
97
- },
98
- [screenSize.width],
99
- );
100
-
101
- const matchesMinWidth = useCallback(
102
- (width: number) => {
103
- return screenSize.width >= width;
104
- },
105
- [screenSize.width],
106
- );
107
-
108
- const matchesMaxWidth = useCallback(
109
- (width: number) => {
110
- return screenSize.width <= width;
111
- },
112
- [screenSize.width],
113
- );
114
-
115
- // 获取响应式值
116
- const getResponsiveValue = useCallback(
117
- <T,>(values: Partial<Record<string, T>>, defaultValue: T): T => {
118
- const currentIndex = breakpointOrder.indexOf(currentBreakpoint as (typeof breakpointOrder)[number]);
119
-
120
- // 从当前断点开始,向上查找第一个匹配的值
121
- for (let i = currentIndex; i >= 0; i--) {
122
- const breakpoint = breakpointOrder[i];
123
- if (values[breakpoint as keyof typeof values] !== undefined) {
124
- return values[breakpoint as keyof typeof values] as T;
125
- }
126
- }
127
-
128
- return defaultValue;
129
- },
130
- [currentBreakpoint],
131
- );
132
-
133
- const contextValue: ResponsiveContextType = {
134
- screenSize,
135
- currentBreakpoint,
136
- isMobile,
137
- isTablet,
138
- isDesktop,
139
- matches,
140
- matchesMinWidth,
141
- matchesMaxWidth,
142
- getResponsiveValue,
143
- };
144
-
145
- return <ResponsiveContext.Provider value={contextValue}>{children}</ResponsiveContext.Provider>;
146
- }
147
-
148
- /**
149
- * 使用响应式上下文的 Hook
150
- */
151
- export function useResponsive() {
152
- const context = useContext(ResponsiveContext);
153
- if (!context) {
154
- throw new Error('useResponsive must be used within a ResponsiveProvider');
155
- }
156
- return context;
157
- }
158
-
159
- /**
160
- * 响应式值 Hook
161
- */
162
- export function useResponsiveValue<T>(values: Partial<Record<string, T>>, defaultValue: T): T {
163
- const { getResponsiveValue } = useResponsive();
164
- return getResponsiveValue(values, defaultValue);
165
- }
166
-
167
- /**
168
- * 断点 Hook
169
- */
170
- export function useBreakpoint(): keyof typeof breakpoints {
171
- const { currentBreakpoint } = useResponsive();
172
- return currentBreakpoint;
173
- }
174
-
175
- /**
176
- * 屏幕尺寸 Hook
177
- */
178
- export function useScreenSize(): ScreenSize {
179
- const { screenSize } = useResponsive();
180
- return screenSize;
181
- }
182
-
183
- /**
184
- * 设备类型 Hook
185
- */
186
- export function useDeviceType() {
187
- const { isMobile, isTablet, isDesktop } = useResponsive();
188
- return {
189
- isMobile,
190
- isTablet,
191
- isDesktop,
192
- };
193
- }
194
-
195
- export default ResponsiveProvider;