@xhsreds/reds-rn-next 0.9.1-beta202510291556 → 0.9.1-feat-swiper202511031535

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 (499) hide show
  1. package/coverage/.tmp/coverage-10.json +1 -1
  2. package/coverage/.tmp/coverage-11.json +1 -1
  3. package/coverage/.tmp/coverage-12.json +1 -1
  4. package/coverage/.tmp/coverage-16.json +1 -1
  5. package/coverage/.tmp/coverage-17.json +1 -1
  6. package/coverage/.tmp/coverage-2.json +1 -1
  7. package/coverage/.tmp/coverage-21.json +1 -1
  8. package/coverage/.tmp/coverage-22.json +1 -1
  9. package/coverage/.tmp/coverage-26.json +1 -1
  10. package/coverage/.tmp/coverage-27.json +1 -1
  11. package/coverage/.tmp/coverage-29.json +1 -1
  12. package/coverage/.tmp/coverage-3.json +1 -1
  13. package/coverage/.tmp/coverage-30.json +1 -1
  14. package/coverage/.tmp/coverage-31.json +1 -1
  15. package/coverage/.tmp/coverage-32.json +1 -1
  16. package/coverage/.tmp/coverage-33.json +1 -1
  17. package/coverage/.tmp/coverage-34.json +1 -1
  18. package/coverage/.tmp/coverage-35.json +1 -1
  19. package/coverage/.tmp/coverage-36.json +1 -1
  20. package/coverage/.tmp/coverage-37.json +1 -1
  21. package/coverage/.tmp/coverage-38.json +1 -1
  22. package/coverage/.tmp/coverage-39.json +1 -1
  23. package/coverage/.tmp/coverage-4.json +1 -1
  24. package/coverage/.tmp/coverage-40.json +1 -1
  25. package/coverage/.tmp/coverage-41.json +1 -1
  26. package/coverage/.tmp/coverage-42.json +1 -1
  27. package/coverage/.tmp/coverage-5.json +1 -1
  28. package/coverage/.tmp/coverage-7.json +1 -1
  29. package/coverage/.tmp/coverage-8.json +1 -1
  30. package/coverage/.tmp/coverage-9.json +1 -1
  31. package/lib/cjs/_chunks/CwkpVXDI.js.map +1 -1
  32. package/lib/cjs/_chunks/{DNr-ZG4Y.js → Dn-t7SiM.js} +2 -2
  33. package/lib/cjs/_chunks/{DNr-ZG4Y.js.map → Dn-t7SiM.js.map} +1 -1
  34. package/lib/cjs/_chunks/{C9tZEm0t.js → hnLc3Qom.js} +8 -10
  35. package/lib/cjs/_chunks/{C9tZEm0t.js.map → hnLc3Qom.js.map} +1 -1
  36. package/lib/cjs/components/ActionSheets/ActionSheets.js +1 -1
  37. package/lib/cjs/components/ActionSheets/ActionSheetsItem.js +1 -1
  38. package/lib/cjs/components/ActionSheets/api.js +1 -1
  39. package/lib/cjs/components/ActionSheets/hooks.js +1 -1
  40. package/lib/cjs/components/ActionSheets/index.js +1 -1
  41. package/lib/cjs/components/ActionablePopover/ActionablePopover.js +1 -1
  42. package/lib/cjs/components/ActionablePopover/index.js +1 -1
  43. package/lib/cjs/components/Alert/Alert.js +1 -1
  44. package/lib/cjs/components/Alert/hooks/alert.js +1 -1
  45. package/lib/cjs/components/Alert/index.js +1 -1
  46. package/lib/cjs/components/Alert/styles.js +1 -1
  47. package/lib/cjs/components/Avatar/Avatar.js +1 -1
  48. package/lib/cjs/components/Avatar/index.js +1 -1
  49. package/lib/cjs/components/Avatar/styles.js +1 -1
  50. package/lib/cjs/components/AvatarGroup/AvatarGroup.js +1 -1
  51. package/lib/cjs/components/AvatarGroup/index.js +1 -1
  52. package/lib/cjs/components/Badge/Badge.js +1 -1
  53. package/lib/cjs/components/Badge/index.js +1 -1
  54. package/lib/cjs/components/Badge/styles.js +1 -1
  55. package/lib/cjs/components/BottomBar/BottomBar.js +1 -1
  56. package/lib/cjs/components/BottomBar/index.js +1 -1
  57. package/lib/cjs/components/Button/Button.js +1 -1
  58. package/lib/cjs/components/Button/Viewable.js +1 -1
  59. package/lib/cjs/components/Button/index.js +1 -1
  60. package/lib/cjs/components/Button/styleMap.js +1 -1
  61. package/lib/cjs/components/Carousel/Carousel.js +3 -10
  62. package/lib/cjs/components/Carousel/Carousel.js.map +1 -1
  63. package/lib/cjs/components/Carousel/index.js +1 -1
  64. package/lib/cjs/components/CheckBoxGroup/CheckBox.js +1 -1
  65. package/lib/cjs/components/CheckBoxGroup/CheckBoxGroup.js +1 -1
  66. package/lib/cjs/components/CheckBoxGroup/index.js +1 -1
  67. package/lib/cjs/components/CheckBoxGroup/styles.js +1 -1
  68. package/lib/cjs/components/Collapse/Collapse.js +1 -1
  69. package/lib/cjs/components/Collapse/Item/Item.js +1 -1
  70. package/lib/cjs/components/Collapse/Item/styles.js +1 -1
  71. package/lib/cjs/components/Collapse/index.js +1 -1
  72. package/lib/cjs/components/ConfigProvider/ConfigProvider.js +1 -1
  73. package/lib/cjs/components/ConfigProvider/hooks/ConfigCache/ConfigCache.js +1 -1
  74. package/lib/cjs/components/ConfigProvider/hooks/ConfigCache/index.js +1 -1
  75. package/lib/cjs/components/ConfigProvider/hooks/themeToken/index.js +1 -1
  76. package/lib/cjs/components/ConfigProvider/hooks/themeToken/useThemeToken.js +1 -1
  77. package/lib/cjs/components/ConfigProvider/index.js +1 -1
  78. package/lib/cjs/components/DatePicker/DatePicker.js +1 -1
  79. package/lib/cjs/components/DatePicker/api.js +1 -1
  80. package/lib/cjs/components/DatePicker/index.js +1 -1
  81. package/lib/cjs/components/Divider/Divider.js +1 -1
  82. package/lib/cjs/components/Divider/index.js +1 -1
  83. package/lib/cjs/components/Divider/styles.js +1 -1
  84. package/lib/cjs/components/DropDown/DropDown.js +1 -1
  85. package/lib/cjs/components/DropDown/DropDownItem.js +1 -1
  86. package/lib/cjs/components/DropDown/index.js +1 -1
  87. package/lib/cjs/components/Empty/Empty.js +1 -1
  88. package/lib/cjs/components/Empty/index.js +1 -1
  89. package/lib/cjs/components/Empty/styles.js +1 -1
  90. package/lib/cjs/components/FAB/FAB.js +1 -1
  91. package/lib/cjs/components/FAB/index.js +1 -1
  92. package/lib/cjs/components/Form/Form.js +1 -1
  93. package/lib/cjs/components/Form/FormItem.js +1 -1
  94. package/lib/cjs/components/Form/index.js +1 -1
  95. package/lib/cjs/components/Form/styles.js +1 -1
  96. package/lib/cjs/components/Image/Image.js +1 -1
  97. package/lib/cjs/components/Image/Image69.js +1 -1
  98. package/lib/cjs/components/Image/VisibilitySensor.js +1 -1
  99. package/lib/cjs/components/Image/hook/index.js +1 -1
  100. package/lib/cjs/components/Image/index.js +1 -1
  101. package/lib/cjs/components/Image/utils.js +1 -1
  102. package/lib/cjs/components/ImagePreview/ImagePreview.js +1 -1
  103. package/lib/cjs/components/ImagePreview/api.js +1 -1
  104. package/lib/cjs/components/ImagePreview/index.js +1 -1
  105. package/lib/cjs/components/LanguageProvider/hooks/useLanguage.js +1 -1
  106. package/lib/cjs/components/LanguageProvider/index.js +1 -1
  107. package/lib/cjs/components/List/List.js +1 -1
  108. package/lib/cjs/components/List/ListItem/ListItem.js +1 -1
  109. package/lib/cjs/components/List/index.js +1 -1
  110. package/lib/cjs/components/List/styles.js +1 -1
  111. package/lib/cjs/components/MiniSnackBar/MiniSnackBar.js +1 -1
  112. package/lib/cjs/components/MiniSnackBar/index.js +1 -1
  113. package/lib/cjs/components/MiniSnackBar/styles.js +1 -1
  114. package/lib/cjs/components/NavigationBar/NavigationBar.js +1 -1
  115. package/lib/cjs/components/NavigationBar/index.js +1 -1
  116. package/lib/cjs/components/NavigationBar/styles.js +1 -1
  117. package/lib/cjs/components/NoticeBar/NoticeBar.js +1 -1
  118. package/lib/cjs/components/NoticeBar/index.js +1 -1
  119. package/lib/cjs/components/Picker/Picker.js +1 -1
  120. package/lib/cjs/components/Picker/api.js +1 -1
  121. package/lib/cjs/components/Picker/index.js +1 -1
  122. package/lib/cjs/components/PickerView/PickerView.js +1 -1
  123. package/lib/cjs/components/PickerView/Wheel.js +1 -1
  124. package/lib/cjs/components/PickerView/index.js +1 -1
  125. package/lib/cjs/components/Popover/Popover.js +4 -5
  126. package/lib/cjs/components/Popover/Popover.js.map +1 -1
  127. package/lib/cjs/components/Popover/index.js +1 -1
  128. package/lib/cjs/components/Portal/core/PortalProvider.js +1 -1
  129. package/lib/cjs/components/Portal/index.js +1 -1
  130. package/lib/cjs/components/Progress/Progress.js +1 -1
  131. package/lib/cjs/components/Progress/index.js +1 -1
  132. package/lib/cjs/components/Progress/styles.js +1 -1
  133. package/lib/cjs/components/ProgressIndicator/ProgressIndicator.js +1 -1
  134. package/lib/cjs/components/ProgressIndicator/index.js +1 -1
  135. package/lib/cjs/components/ProgressIndicator/styles.js +1 -1
  136. package/lib/cjs/components/PullRefresh/PullRefresh.js +1 -1
  137. package/lib/cjs/components/PullRefresh/component.js +1 -1
  138. package/lib/cjs/components/PullRefresh/index.js +1 -1
  139. package/lib/cjs/components/Radio/Radio.js +8 -2
  140. package/lib/cjs/components/Radio/Radio.js.map +1 -1
  141. package/lib/cjs/components/Radio/RadioGroup.js +1 -1
  142. package/lib/cjs/components/Radio/index.js +8 -2
  143. package/lib/cjs/components/Radio/index.js.map +1 -1
  144. package/lib/cjs/components/Radio/styles.js +1 -1
  145. package/lib/cjs/components/Rate/Rate.js +1 -1
  146. package/lib/cjs/components/Rate/index.js +1 -1
  147. package/lib/cjs/components/Result/Result.js +1 -1
  148. package/lib/cjs/components/Result/index.js +1 -1
  149. package/lib/cjs/components/Result/styles.js +1 -1
  150. package/lib/cjs/components/Search/Search.js +1 -1
  151. package/lib/cjs/components/Search/index.js +1 -1
  152. package/lib/cjs/components/Search/styles.js +1 -1
  153. package/lib/cjs/components/SegmentedControl/SegmentedControl.js +1 -1
  154. package/lib/cjs/components/SegmentedControl/index.js +1 -1
  155. package/lib/cjs/components/Sheets/AnimatedSheets.js +1 -1
  156. package/lib/cjs/components/Sheets/Sheets.js +1 -1
  157. package/lib/cjs/components/Sheets/api.js +1 -1
  158. package/lib/cjs/components/Sheets/index.js +1 -1
  159. package/lib/cjs/components/Sheets/styles.js +2 -2
  160. package/lib/cjs/components/Sheets/styles.js.map +1 -1
  161. package/lib/cjs/components/Skeleton/Item/SkeletonItem.js +1 -1
  162. package/lib/cjs/components/Skeleton/Item/SkeletonItem69.js +1 -1
  163. package/lib/cjs/components/Skeleton/Skeleton.js +1 -1
  164. package/lib/cjs/components/Skeleton/Skeleton69.js +1 -1
  165. package/lib/cjs/components/Skeleton/index.js +1 -1
  166. package/lib/cjs/components/Slider/Slider.js +1 -1
  167. package/lib/cjs/components/Slider/index.js +1 -1
  168. package/lib/cjs/components/SlimAlert/Alert.js +1 -1
  169. package/lib/cjs/components/SlimAlert/AlertContent.js +1 -1
  170. package/lib/cjs/components/SlimAlert/AlertFooter.js +1 -1
  171. package/lib/cjs/components/SlimAlert/index.js +1 -1
  172. package/lib/cjs/components/SlimAlert/styles.js +1 -1
  173. package/lib/cjs/components/SlimNavigationBar/NavigationBar.js +1 -1
  174. package/lib/cjs/components/SlimNavigationBar/NavigationBarAction.js +1 -1
  175. package/lib/cjs/components/SlimNavigationBar/index.js +1 -1
  176. package/lib/cjs/components/SlimNavigationBar/styles.js +1 -1
  177. package/lib/cjs/components/SlimSheets/AnimatedSheets.js +1 -1
  178. package/lib/cjs/components/SlimSheets/AnimatedSheetsAction.js +1 -1
  179. package/lib/cjs/components/SlimSheets/AnimatedSheetsHeader.js +1 -1
  180. package/lib/cjs/components/SlimSheets/DragAnimatedSheets.js +1 -1
  181. package/lib/cjs/components/SlimSheets/index.js +1 -1
  182. package/lib/cjs/components/SlimTabs/BadgeSlimTabItem.js +1 -1
  183. package/lib/cjs/components/SlimTabs/SlimTab.js +1 -1
  184. package/lib/cjs/components/SlimTabs/SlimTabItem.js +1 -1
  185. package/lib/cjs/components/SlimTabs/SlimTabItemLabel.js +1 -1
  186. package/lib/cjs/components/SlimTabs/SlimTabItemValue.js +1 -1
  187. package/lib/cjs/components/SlimTabs/SlimTabList.js +1 -1
  188. package/lib/cjs/components/SlimTabs/index.js +1 -1
  189. package/lib/cjs/components/SlimTabs/styles.js +1 -1
  190. package/lib/cjs/components/SnackBar/SnackBar.js +1 -1
  191. package/lib/cjs/components/SnackBar/index.js +1 -1
  192. package/lib/cjs/components/SnackBar/styles.js +1 -1
  193. package/lib/cjs/components/Stepper/Stepper.js +1 -1
  194. package/lib/cjs/components/Stepper/index.js +1 -1
  195. package/lib/cjs/components/Swiper/LazyPage.js +42 -0
  196. package/lib/cjs/components/Swiper/LazyPage.js.map +1 -0
  197. package/lib/cjs/components/Swiper/Swiper.js +27 -0
  198. package/lib/cjs/components/Swiper/Swiper.js.map +1 -0
  199. package/lib/cjs/components/Swiper/SwiperFlatList.js +227 -0
  200. package/lib/cjs/components/Swiper/SwiperFlatList.js.map +1 -0
  201. package/lib/cjs/components/Swiper/SwiperPagerView.js +231 -0
  202. package/lib/cjs/components/Swiper/SwiperPagerView.js.map +1 -0
  203. package/lib/cjs/components/Swiper/index.js +16 -0
  204. package/lib/cjs/components/Swiper/index.js.map +1 -0
  205. package/lib/cjs/components/Swiper/types.js +3 -0
  206. package/lib/cjs/components/Swiper/types.js.map +1 -0
  207. package/lib/cjs/components/Swiper/utils.js +73 -0
  208. package/lib/cjs/components/Swiper/utils.js.map +1 -0
  209. package/lib/cjs/components/Switch/Switch.js +1 -1
  210. package/lib/cjs/components/Switch/index.js +1 -1
  211. package/lib/cjs/components/Tab/Tabs.js +1 -1
  212. package/lib/cjs/components/Tab/index.js +1 -1
  213. package/lib/cjs/components/Tab/styles.js +1 -1
  214. package/lib/cjs/components/TabBar/TabBar.js +1 -1
  215. package/lib/cjs/components/TabBar/index.js +1 -1
  216. package/lib/cjs/components/TabBar/styles.js +1 -1
  217. package/lib/cjs/components/Tag/Tag.js +1 -1
  218. package/lib/cjs/components/Tag/index.js +1 -1
  219. package/lib/cjs/components/Text/Text.js +1 -1
  220. package/lib/cjs/components/Text/Viewable.js +1 -1
  221. package/lib/cjs/components/Text/hooks/cloneContainer.js +1 -1
  222. package/lib/cjs/components/Text/hooks/index.js +1 -1
  223. package/lib/cjs/components/Text/hooks/loadFontFromFile.js +2 -2
  224. package/lib/cjs/components/Text/hooks/loadFontFromFile.js.map +1 -1
  225. package/lib/cjs/components/Text/index.js +1 -1
  226. package/lib/cjs/components/Text/styles.js +1 -1
  227. package/lib/cjs/components/TextField/TextField.js +1 -1
  228. package/lib/cjs/components/TextField/index.js +1 -1
  229. package/lib/cjs/components/TextField/styles.js +1 -1
  230. package/lib/cjs/components/TextView/TextView.js +1 -1
  231. package/lib/cjs/components/TextView/index.js +1 -1
  232. package/lib/cjs/components/TextView/styles.js +1 -1
  233. package/lib/cjs/components/Toast/Toast.js +1 -1
  234. package/lib/cjs/components/Toast/api.js +1 -1
  235. package/lib/cjs/components/Toast/index.js +1 -1
  236. package/lib/cjs/components/Toast/styles.js +1 -1
  237. package/lib/cjs/components/Uploader/Uploader.js +3 -3
  238. package/lib/cjs/components/Uploader/Uploader.js.map +1 -1
  239. package/lib/cjs/components/Uploader/index.js +2 -2
  240. package/lib/cjs/components/Uploader/interface/index.js +2 -2
  241. package/lib/cjs/components/Uploader/styles.js +2 -2
  242. package/lib/cjs/components/Uploader/utils.js +1 -1
  243. package/lib/cjs/index.js +9 -2
  244. package/lib/cjs/index.js.map +1 -1
  245. package/lib/cjs/pvCount/pvData.js +1 -0
  246. package/lib/cjs/pvCount/pvData.js.map +1 -1
  247. package/lib/esm/_chunks/{CAkwE9ZD.js → CgvIDP0E.js} +8 -10
  248. package/lib/esm/_chunks/{CAkwE9ZD.js.map → CgvIDP0E.js.map} +1 -1
  249. package/lib/esm/_chunks/{eYElHgNc.js → DRgGcbc8.js} +2 -2
  250. package/lib/esm/_chunks/{eYElHgNc.js.map → DRgGcbc8.js.map} +1 -1
  251. package/lib/esm/_chunks/Da9cW8JG.js.map +1 -1
  252. package/lib/esm/components/ActionSheets/ActionSheets.js +1 -1
  253. package/lib/esm/components/ActionSheets/ActionSheetsItem.js +1 -1
  254. package/lib/esm/components/ActionSheets/api.js +1 -1
  255. package/lib/esm/components/ActionSheets/hooks.js +1 -1
  256. package/lib/esm/components/ActionSheets/index.js +1 -1
  257. package/lib/esm/components/ActionablePopover/ActionablePopover.js +1 -1
  258. package/lib/esm/components/ActionablePopover/index.js +1 -1
  259. package/lib/esm/components/Alert/Alert.js +1 -1
  260. package/lib/esm/components/Alert/hooks/alert.js +1 -1
  261. package/lib/esm/components/Alert/index.js +1 -1
  262. package/lib/esm/components/Alert/styles.js +1 -1
  263. package/lib/esm/components/Avatar/Avatar.js +1 -1
  264. package/lib/esm/components/Avatar/index.js +1 -1
  265. package/lib/esm/components/Avatar/styles.js +1 -1
  266. package/lib/esm/components/AvatarGroup/AvatarGroup.js +1 -1
  267. package/lib/esm/components/AvatarGroup/index.js +1 -1
  268. package/lib/esm/components/Badge/Badge.js +1 -1
  269. package/lib/esm/components/Badge/index.js +1 -1
  270. package/lib/esm/components/Badge/styles.js +1 -1
  271. package/lib/esm/components/BottomBar/BottomBar.js +1 -1
  272. package/lib/esm/components/BottomBar/index.js +1 -1
  273. package/lib/esm/components/Button/Button.js +1 -1
  274. package/lib/esm/components/Button/Viewable.js +1 -1
  275. package/lib/esm/components/Button/index.js +1 -1
  276. package/lib/esm/components/Button/styleMap.js +1 -1
  277. package/lib/esm/components/Carousel/Carousel.js +3 -10
  278. package/lib/esm/components/Carousel/Carousel.js.map +1 -1
  279. package/lib/esm/components/Carousel/index.js +1 -1
  280. package/lib/esm/components/CheckBoxGroup/CheckBox.js +1 -1
  281. package/lib/esm/components/CheckBoxGroup/CheckBoxGroup.js +1 -1
  282. package/lib/esm/components/CheckBoxGroup/index.js +1 -1
  283. package/lib/esm/components/CheckBoxGroup/styles.js +1 -1
  284. package/lib/esm/components/Collapse/Collapse.js +1 -1
  285. package/lib/esm/components/Collapse/Item/Item.js +1 -1
  286. package/lib/esm/components/Collapse/Item/styles.js +1 -1
  287. package/lib/esm/components/Collapse/index.js +1 -1
  288. package/lib/esm/components/ConfigProvider/ConfigProvider.js +1 -1
  289. package/lib/esm/components/ConfigProvider/hooks/ConfigCache/ConfigCache.js +1 -1
  290. package/lib/esm/components/ConfigProvider/hooks/ConfigCache/index.js +1 -1
  291. package/lib/esm/components/ConfigProvider/hooks/themeToken/index.js +1 -1
  292. package/lib/esm/components/ConfigProvider/hooks/themeToken/useThemeToken.js +1 -1
  293. package/lib/esm/components/ConfigProvider/index.js +1 -1
  294. package/lib/esm/components/DatePicker/DatePicker.js +1 -1
  295. package/lib/esm/components/DatePicker/api.js +1 -1
  296. package/lib/esm/components/DatePicker/index.js +1 -1
  297. package/lib/esm/components/Divider/Divider.js +1 -1
  298. package/lib/esm/components/Divider/index.js +1 -1
  299. package/lib/esm/components/Divider/styles.js +1 -1
  300. package/lib/esm/components/DropDown/DropDown.js +1 -1
  301. package/lib/esm/components/DropDown/DropDownItem.js +1 -1
  302. package/lib/esm/components/DropDown/index.js +1 -1
  303. package/lib/esm/components/Empty/Empty.js +1 -1
  304. package/lib/esm/components/Empty/index.js +1 -1
  305. package/lib/esm/components/Empty/styles.js +1 -1
  306. package/lib/esm/components/FAB/FAB.js +1 -1
  307. package/lib/esm/components/FAB/index.js +1 -1
  308. package/lib/esm/components/Form/Form.js +1 -1
  309. package/lib/esm/components/Form/FormItem.js +1 -1
  310. package/lib/esm/components/Form/index.js +1 -1
  311. package/lib/esm/components/Form/styles.js +1 -1
  312. package/lib/esm/components/Image/Image.js +1 -1
  313. package/lib/esm/components/Image/Image69.js +1 -1
  314. package/lib/esm/components/Image/VisibilitySensor.js +1 -1
  315. package/lib/esm/components/Image/hook/index.js +1 -1
  316. package/lib/esm/components/Image/index.js +1 -1
  317. package/lib/esm/components/Image/utils.js +1 -1
  318. package/lib/esm/components/ImagePreview/ImagePreview.js +1 -1
  319. package/lib/esm/components/ImagePreview/api.js +1 -1
  320. package/lib/esm/components/ImagePreview/index.js +1 -1
  321. package/lib/esm/components/LanguageProvider/hooks/useLanguage.js +1 -1
  322. package/lib/esm/components/LanguageProvider/index.js +1 -1
  323. package/lib/esm/components/List/List.js +1 -1
  324. package/lib/esm/components/List/ListItem/ListItem.js +1 -1
  325. package/lib/esm/components/List/index.js +1 -1
  326. package/lib/esm/components/List/styles.js +1 -1
  327. package/lib/esm/components/MiniSnackBar/MiniSnackBar.js +1 -1
  328. package/lib/esm/components/MiniSnackBar/index.js +1 -1
  329. package/lib/esm/components/MiniSnackBar/styles.js +1 -1
  330. package/lib/esm/components/NavigationBar/NavigationBar.js +1 -1
  331. package/lib/esm/components/NavigationBar/index.js +1 -1
  332. package/lib/esm/components/NavigationBar/styles.js +1 -1
  333. package/lib/esm/components/NoticeBar/NoticeBar.js +1 -1
  334. package/lib/esm/components/NoticeBar/index.js +1 -1
  335. package/lib/esm/components/Picker/Picker.js +1 -1
  336. package/lib/esm/components/Picker/api.js +1 -1
  337. package/lib/esm/components/Picker/index.js +1 -1
  338. package/lib/esm/components/PickerView/PickerView.js +1 -1
  339. package/lib/esm/components/PickerView/Wheel.js +1 -1
  340. package/lib/esm/components/PickerView/index.js +1 -1
  341. package/lib/esm/components/Popover/Popover.js +4 -5
  342. package/lib/esm/components/Popover/Popover.js.map +1 -1
  343. package/lib/esm/components/Popover/index.js +1 -1
  344. package/lib/esm/components/Portal/core/PortalProvider.js +1 -1
  345. package/lib/esm/components/Portal/index.js +1 -1
  346. package/lib/esm/components/Progress/Progress.js +1 -1
  347. package/lib/esm/components/Progress/index.js +1 -1
  348. package/lib/esm/components/Progress/styles.js +1 -1
  349. package/lib/esm/components/ProgressIndicator/ProgressIndicator.js +1 -1
  350. package/lib/esm/components/ProgressIndicator/index.js +1 -1
  351. package/lib/esm/components/ProgressIndicator/styles.js +1 -1
  352. package/lib/esm/components/PullRefresh/PullRefresh.js +1 -1
  353. package/lib/esm/components/PullRefresh/component.js +1 -1
  354. package/lib/esm/components/PullRefresh/index.js +1 -1
  355. package/lib/esm/components/Radio/Radio.js +8 -2
  356. package/lib/esm/components/Radio/Radio.js.map +1 -1
  357. package/lib/esm/components/Radio/RadioGroup.js +1 -1
  358. package/lib/esm/components/Radio/index.js +8 -2
  359. package/lib/esm/components/Radio/index.js.map +1 -1
  360. package/lib/esm/components/Radio/styles.js +1 -1
  361. package/lib/esm/components/Rate/Rate.js +1 -1
  362. package/lib/esm/components/Rate/index.js +1 -1
  363. package/lib/esm/components/Result/Result.js +1 -1
  364. package/lib/esm/components/Result/index.js +1 -1
  365. package/lib/esm/components/Result/styles.js +1 -1
  366. package/lib/esm/components/Search/Search.js +1 -1
  367. package/lib/esm/components/Search/index.js +1 -1
  368. package/lib/esm/components/Search/styles.js +1 -1
  369. package/lib/esm/components/SegmentedControl/SegmentedControl.js +1 -1
  370. package/lib/esm/components/SegmentedControl/index.js +1 -1
  371. package/lib/esm/components/Sheets/AnimatedSheets.js +1 -1
  372. package/lib/esm/components/Sheets/Sheets.js +1 -1
  373. package/lib/esm/components/Sheets/api.js +1 -1
  374. package/lib/esm/components/Sheets/index.js +1 -1
  375. package/lib/esm/components/Sheets/styles.js +2 -2
  376. package/lib/esm/components/Sheets/styles.js.map +1 -1
  377. package/lib/esm/components/Skeleton/Item/SkeletonItem.js +1 -1
  378. package/lib/esm/components/Skeleton/Item/SkeletonItem69.js +1 -1
  379. package/lib/esm/components/Skeleton/Skeleton.js +1 -1
  380. package/lib/esm/components/Skeleton/Skeleton69.js +1 -1
  381. package/lib/esm/components/Skeleton/index.js +1 -1
  382. package/lib/esm/components/Slider/Slider.js +1 -1
  383. package/lib/esm/components/Slider/index.js +1 -1
  384. package/lib/esm/components/SlimAlert/Alert.js +1 -1
  385. package/lib/esm/components/SlimAlert/AlertContent.js +1 -1
  386. package/lib/esm/components/SlimAlert/AlertFooter.js +1 -1
  387. package/lib/esm/components/SlimAlert/index.js +1 -1
  388. package/lib/esm/components/SlimAlert/styles.js +1 -1
  389. package/lib/esm/components/SlimNavigationBar/NavigationBar.js +1 -1
  390. package/lib/esm/components/SlimNavigationBar/NavigationBarAction.js +1 -1
  391. package/lib/esm/components/SlimNavigationBar/index.js +1 -1
  392. package/lib/esm/components/SlimNavigationBar/styles.js +1 -1
  393. package/lib/esm/components/SlimSheets/AnimatedSheets.js +1 -1
  394. package/lib/esm/components/SlimSheets/AnimatedSheetsAction.js +1 -1
  395. package/lib/esm/components/SlimSheets/AnimatedSheetsHeader.js +1 -1
  396. package/lib/esm/components/SlimSheets/DragAnimatedSheets.js +1 -1
  397. package/lib/esm/components/SlimSheets/index.js +1 -1
  398. package/lib/esm/components/SlimTabs/BadgeSlimTabItem.js +1 -1
  399. package/lib/esm/components/SlimTabs/SlimTab.js +1 -1
  400. package/lib/esm/components/SlimTabs/SlimTabItem.js +1 -1
  401. package/lib/esm/components/SlimTabs/SlimTabItemLabel.js +1 -1
  402. package/lib/esm/components/SlimTabs/SlimTabItemValue.js +1 -1
  403. package/lib/esm/components/SlimTabs/SlimTabList.js +1 -1
  404. package/lib/esm/components/SlimTabs/index.js +1 -1
  405. package/lib/esm/components/SlimTabs/styles.js +1 -1
  406. package/lib/esm/components/SnackBar/SnackBar.js +1 -1
  407. package/lib/esm/components/SnackBar/index.js +1 -1
  408. package/lib/esm/components/SnackBar/styles.js +1 -1
  409. package/lib/esm/components/Stepper/Stepper.js +1 -1
  410. package/lib/esm/components/Stepper/index.js +1 -1
  411. package/lib/esm/components/Swiper/LazyPage.js +40 -0
  412. package/lib/esm/components/Swiper/LazyPage.js.map +1 -0
  413. package/lib/esm/components/Swiper/Swiper.js +25 -0
  414. package/lib/esm/components/Swiper/Swiper.js.map +1 -0
  415. package/lib/esm/components/Swiper/SwiperFlatList.js +225 -0
  416. package/lib/esm/components/Swiper/SwiperFlatList.js.map +1 -0
  417. package/lib/esm/components/Swiper/SwiperPagerView.js +229 -0
  418. package/lib/esm/components/Swiper/SwiperPagerView.js.map +1 -0
  419. package/lib/esm/components/Swiper/index.js +10 -0
  420. package/lib/esm/components/Swiper/index.js.map +1 -0
  421. package/lib/esm/components/Swiper/types.js +2 -0
  422. package/lib/esm/components/Swiper/types.js.map +1 -0
  423. package/lib/esm/components/Swiper/utils.js +68 -0
  424. package/lib/esm/components/Swiper/utils.js.map +1 -0
  425. package/lib/esm/components/Switch/Switch.js +1 -1
  426. package/lib/esm/components/Switch/index.js +1 -1
  427. package/lib/esm/components/Tab/Tabs.js +1 -1
  428. package/lib/esm/components/Tab/index.js +1 -1
  429. package/lib/esm/components/Tab/styles.js +1 -1
  430. package/lib/esm/components/TabBar/TabBar.js +1 -1
  431. package/lib/esm/components/TabBar/index.js +1 -1
  432. package/lib/esm/components/TabBar/styles.js +1 -1
  433. package/lib/esm/components/Tag/Tag.js +1 -1
  434. package/lib/esm/components/Tag/index.js +1 -1
  435. package/lib/esm/components/Text/Text.js +1 -1
  436. package/lib/esm/components/Text/Viewable.js +1 -1
  437. package/lib/esm/components/Text/hooks/cloneContainer.js +1 -1
  438. package/lib/esm/components/Text/hooks/index.js +1 -1
  439. package/lib/esm/components/Text/hooks/loadFontFromFile.js +2 -2
  440. package/lib/esm/components/Text/hooks/loadFontFromFile.js.map +1 -1
  441. package/lib/esm/components/Text/index.js +1 -1
  442. package/lib/esm/components/Text/styles.js +1 -1
  443. package/lib/esm/components/TextField/TextField.js +1 -1
  444. package/lib/esm/components/TextField/index.js +1 -1
  445. package/lib/esm/components/TextField/styles.js +1 -1
  446. package/lib/esm/components/TextView/TextView.js +1 -1
  447. package/lib/esm/components/TextView/index.js +1 -1
  448. package/lib/esm/components/TextView/styles.js +1 -1
  449. package/lib/esm/components/Toast/Toast.js +1 -1
  450. package/lib/esm/components/Toast/api.js +1 -1
  451. package/lib/esm/components/Toast/index.js +1 -1
  452. package/lib/esm/components/Toast/styles.js +1 -1
  453. package/lib/esm/components/Uploader/Uploader.js +3 -3
  454. package/lib/esm/components/Uploader/Uploader.js.map +1 -1
  455. package/lib/esm/components/Uploader/index.js +2 -2
  456. package/lib/esm/components/Uploader/interface/index.js +2 -2
  457. package/lib/esm/components/Uploader/styles.js +2 -2
  458. package/lib/esm/components/Uploader/utils.js +1 -1
  459. package/lib/esm/index.js +8 -2
  460. package/lib/esm/index.js.map +1 -1
  461. package/lib/esm/pvCount/pvData.js +1 -0
  462. package/lib/esm/pvCount/pvData.js.map +1 -1
  463. package/lib/src/components/Popover/Popover.d.ts +1 -1
  464. package/lib/src/components/Popover/interface/index.d.ts +0 -1
  465. package/lib/src/components/Swiper/LazyPage.d.ts +7 -0
  466. package/lib/src/components/Swiper/Swiper.d.ts +5 -0
  467. package/lib/src/components/Swiper/SwiperFlatList.d.ts +5 -0
  468. package/lib/src/components/Swiper/SwiperPagerView.d.ts +5 -0
  469. package/lib/src/components/Swiper/index.d.ts +24 -0
  470. package/lib/src/components/Swiper/types.d.ts +166 -0
  471. package/lib/src/components/Swiper/utils.d.ts +42 -0
  472. package/lib/src/index.d.ts +1 -0
  473. package/lib/types/components/Popover/Popover.d.ts +1 -1
  474. package/lib/types/components/Popover/interface/index.d.ts +0 -1
  475. package/lib/types/components/Swiper/LazyPage.d.ts +7 -0
  476. package/lib/types/components/Swiper/Swiper.d.ts +5 -0
  477. package/lib/types/components/Swiper/SwiperFlatList.d.ts +5 -0
  478. package/lib/types/components/Swiper/SwiperPagerView.d.ts +5 -0
  479. package/lib/types/components/Swiper/index.d.ts +24 -0
  480. package/lib/types/components/Swiper/types.d.ts +166 -0
  481. package/lib/types/components/Swiper/utils.d.ts +42 -0
  482. package/lib/types/index.d.ts +1 -0
  483. package/package.json +3 -2
  484. package/src/components/Carousel/Carousel.tsx +3 -15
  485. package/src/components/Carousel/demo/index.tsx +2 -14
  486. package/src/components/Popover/Popover.tsx +3 -4
  487. package/src/components/Popover/doc/index.mdx +21 -22
  488. package/src/components/Popover/interface/index.ts +0 -1
  489. package/src/components/Sheets/styles.ts +2 -2
  490. package/src/components/Swiper/LazyPage.tsx +44 -0
  491. package/src/components/Swiper/Swiper.tsx +31 -0
  492. package/src/components/Swiper/SwiperFlatList.tsx +299 -0
  493. package/src/components/Swiper/SwiperPagerView.tsx +286 -0
  494. package/src/components/Swiper/demo/index.tsx +146 -0
  495. package/src/components/Swiper/doc/index.mdx +49 -0
  496. package/src/components/Swiper/index.ts +25 -0
  497. package/src/components/Swiper/types.ts +208 -0
  498. package/src/components/Swiper/utils.ts +133 -0
  499. package/src/index.ts +1 -0
@@ -0,0 +1,286 @@
1
+ import React, { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useRef, useState } from "react";
2
+ import { StyleSheet } from "react-native";
3
+ import PagerView from "react-native-pager-view";
4
+ import type { PagerViewOnPageSelectedEvent, PageScrollStateChangedNativeEvent } from "react-native-pager-view";
5
+ import { LazyPage } from "./LazyPage";
6
+ import type { SwiperProps, SwiperRef } from "./types";
7
+ import { prepareInfiniteData, shouldJumpForInfinite, getRealIndex, getDisplayIndex } from "./utils";
8
+
9
+ /**
10
+ * PagerView-based Swiper implementation
11
+ */
12
+ function SwiperPagerViewComponent<T>(props: SwiperProps<T>, ref: React.Ref<SwiperRef>) {
13
+ const {
14
+ data,
15
+ renderItem,
16
+ keyExtractor,
17
+ infinite = false,
18
+ initialPage = 0,
19
+ cloneCount = 2,
20
+ lazyMountWindow = 2,
21
+ removeClippedPages = false,
22
+ unmountThreshold,
23
+ onPageChange,
24
+ onNext,
25
+ onPrev,
26
+ onPageScrollStateChanged,
27
+ style,
28
+ pageMargin,
29
+ offscreenPageLimit,
30
+ scrollEnabled = true,
31
+ overdrag,
32
+ renderPlaceholder,
33
+ } = props;
34
+
35
+ // Refs
36
+ const pagerRef = useRef<PagerView>(null);
37
+ const currentPageRef = useRef<number>(initialPage);
38
+ const isJumpingRef = useRef<boolean>(false);
39
+ const pendingJumpRef = useRef<number | null>(null);
40
+ const scrollStateRef = useRef<"idle" | "dragging" | "settling">("idle");
41
+
42
+ // State
43
+ const [currentPage, setCurrentPage] = useState(initialPage);
44
+ const [mountedPages, setMountedPages] = useState<Set<number>>(new Set());
45
+ const [unmountPages, setUnmountPages] = useState<Set<number>>(new Set());
46
+
47
+ // Prepare data for infinite scrolling
48
+ const {
49
+ displayData,
50
+ offset,
51
+ cloneCount: actualCloneCount,
52
+ } = useMemo(() => {
53
+ return prepareInfiniteData(data, infinite, cloneCount);
54
+ }, [data, infinite, cloneCount]);
55
+
56
+ // Calculate adjusted initial page for infinite mode
57
+ const adjustedInitialPage = useMemo(() => {
58
+ return infinite ? getDisplayIndex(initialPage, offset) : initialPage;
59
+ }, [infinite, initialPage, offset]);
60
+
61
+ /**
62
+ * Update which pages should be mounted/unmounted based on current page
63
+ */
64
+ const updateMountedPages = useCallback(
65
+ (centerPage: number) => {
66
+ const newMounted = new Set<number>();
67
+ const newUnmount = new Set<number>();
68
+
69
+ // Scale mount window with clone count for better fast scrolling
70
+ const effectiveMountWindow = Math.max(lazyMountWindow, Math.min(10, Math.ceil(actualCloneCount / 10)));
71
+
72
+ // Calculate unmount threshold (default: 3x mount window)
73
+ const effectiveUnmountThreshold = unmountThreshold ?? effectiveMountWindow * 3;
74
+
75
+ // Mount pages within the window
76
+ for (let i = centerPage - effectiveMountWindow; i <= centerPage + effectiveMountWindow; i++) {
77
+ if (i >= 0 && i < displayData.length) {
78
+ newMounted.add(i);
79
+ }
80
+ }
81
+
82
+ // Mark pages for unmounting if removeClippedPages is enabled
83
+ if (removeClippedPages) {
84
+ for (let i = 0; i < displayData.length; i++) {
85
+ const distance = Math.abs(i - centerPage);
86
+ if (distance > effectiveUnmountThreshold) {
87
+ newUnmount.add(i);
88
+ }
89
+ }
90
+ }
91
+
92
+ console.log("Mounted pages:", Array.from(newMounted));
93
+ console.log("Unmount pages:", Array.from(newUnmount));
94
+
95
+ setMountedPages(newMounted);
96
+ setUnmountPages(newUnmount);
97
+ },
98
+ [lazyMountWindow, displayData.length, actualCloneCount, unmountThreshold, removeClippedPages],
99
+ );
100
+
101
+ /**
102
+ * Handle page selection from PagerView
103
+ */
104
+ const handlePageSelected = useCallback(
105
+ (event: PagerViewOnPageSelectedEvent) => {
106
+ const newDisplayPage = event.nativeEvent.position;
107
+
108
+ if (isJumpingRef.current) {
109
+ return;
110
+ }
111
+
112
+ const realIndex = getRealIndex(newDisplayPage, offset, data.length);
113
+ const prevDisplayPage = currentPageRef.current;
114
+
115
+ setCurrentPage(realIndex);
116
+ currentPageRef.current = newDisplayPage;
117
+
118
+ updateMountedPages(newDisplayPage);
119
+
120
+ onPageChange?.(realIndex);
121
+
122
+ if (newDisplayPage > prevDisplayPage) {
123
+ onNext?.(realIndex);
124
+ } else if (newDisplayPage < prevDisplayPage) {
125
+ onPrev?.(realIndex);
126
+ }
127
+
128
+ // Handle infinite scroll jump
129
+ if (infinite && data.length >= 3) {
130
+ const jumpResult = shouldJumpForInfinite(newDisplayPage, data.length, offset, actualCloneCount);
131
+
132
+ if (jumpResult.shouldJump && jumpResult.jumpTo !== undefined) {
133
+ pendingJumpRef.current = jumpResult.jumpTo;
134
+ }
135
+ }
136
+ },
137
+ [data.length, offset, actualCloneCount, infinite, onPageChange, onNext, onPrev, updateMountedPages],
138
+ );
139
+
140
+ /**
141
+ * Handle scroll state changes
142
+ */
143
+ const handlePageScrollStateChanged = useCallback(
144
+ (event: PageScrollStateChangedNativeEvent) => {
145
+ const state = event.nativeEvent.pageScrollState;
146
+ scrollStateRef.current = state;
147
+ onPageScrollStateChanged?.(state);
148
+
149
+ // Execute pending jump when scroll becomes idle
150
+ if (state === "idle" && pendingJumpRef.current !== null) {
151
+ const targetPage = pendingJumpRef.current;
152
+ pendingJumpRef.current = null;
153
+
154
+ isJumpingRef.current = true;
155
+
156
+ requestAnimationFrame(() => {
157
+ pagerRef.current?.setPageWithoutAnimation(targetPage);
158
+ currentPageRef.current = targetPage;
159
+
160
+ setTimeout(() => {
161
+ isJumpingRef.current = false;
162
+ }, 50);
163
+ });
164
+ }
165
+ },
166
+ [onPageScrollStateChanged],
167
+ );
168
+
169
+ /**
170
+ * Initialize mounted pages on mount
171
+ */
172
+ useEffect(() => {
173
+ updateMountedPages(adjustedInitialPage);
174
+ }, [adjustedInitialPage, updateMountedPages]);
175
+
176
+ /**
177
+ * Expose ref methods for programmatic control
178
+ */
179
+ useImperativeHandle(
180
+ ref,
181
+ () => ({
182
+ goToPage: (index: number, animated = true) => {
183
+ const clampedIndex = Math.max(0, Math.min(index, data.length - 1));
184
+ const displayIndex = infinite ? getDisplayIndex(clampedIndex, offset) : clampedIndex;
185
+
186
+ if (animated) {
187
+ pagerRef.current?.setPage(displayIndex);
188
+ } else {
189
+ pagerRef.current?.setPageWithoutAnimation(displayIndex);
190
+ }
191
+ },
192
+
193
+ next: (animated = true) => {
194
+ const nextPage = currentPage + 1;
195
+
196
+ if (infinite) {
197
+ const displayIndex = getDisplayIndex(nextPage % data.length, offset);
198
+ if (animated) {
199
+ pagerRef.current?.setPage(currentPageRef.current + 1);
200
+ } else {
201
+ pagerRef.current?.setPageWithoutAnimation(currentPageRef.current + 1);
202
+ }
203
+ } else {
204
+ if (nextPage < data.length) {
205
+ if (animated) {
206
+ pagerRef.current?.setPage(nextPage);
207
+ } else {
208
+ pagerRef.current?.setPageWithoutAnimation(nextPage);
209
+ }
210
+ }
211
+ }
212
+ },
213
+
214
+ prev: (animated = true) => {
215
+ const prevPage = currentPage - 1;
216
+
217
+ if (infinite) {
218
+ const displayIndex = getDisplayIndex((prevPage + data.length) % data.length, offset);
219
+ if (animated) {
220
+ pagerRef.current?.setPage(currentPageRef.current - 1);
221
+ } else {
222
+ pagerRef.current?.setPageWithoutAnimation(currentPageRef.current - 1);
223
+ }
224
+ } else {
225
+ if (prevPage >= 0) {
226
+ if (animated) {
227
+ pagerRef.current?.setPage(prevPage);
228
+ } else {
229
+ pagerRef.current?.setPageWithoutAnimation(prevPage);
230
+ }
231
+ }
232
+ }
233
+ },
234
+
235
+ getCurrentPage: () => currentPage,
236
+ }),
237
+ [currentPage, data.length, infinite, offset],
238
+ );
239
+
240
+ // Handle empty data
241
+ if (data.length === 0) {
242
+ return null;
243
+ }
244
+
245
+ return (
246
+ <PagerView
247
+ ref={pagerRef}
248
+ style={[styles.pager, style]}
249
+ initialPage={adjustedInitialPage}
250
+ onPageSelected={handlePageSelected}
251
+ onPageScrollStateChanged={handlePageScrollStateChanged}
252
+ pageMargin={pageMargin}
253
+ offscreenPageLimit={offscreenPageLimit}
254
+ scrollEnabled={scrollEnabled}
255
+ overdrag={overdrag}
256
+ >
257
+ {displayData.map((item, displayIndex) => {
258
+ const realIndex = getRealIndex(displayIndex, offset, data.length);
259
+ const shouldMount = mountedPages.has(displayIndex);
260
+ const shouldUnmount = unmountPages.has(displayIndex);
261
+ const key = keyExtractor?.(item, realIndex) ?? `swiper-page-${displayIndex}`;
262
+
263
+ return (
264
+ <LazyPage
265
+ key={key}
266
+ shouldMount={shouldMount}
267
+ shouldUnmount={shouldUnmount}
268
+ placeholder={renderPlaceholder?.(realIndex)}
269
+ >
270
+ {renderItem(item, realIndex)}
271
+ </LazyPage>
272
+ );
273
+ })}
274
+ </PagerView>
275
+ );
276
+ }
277
+
278
+ const styles = StyleSheet.create({
279
+ pager: {
280
+ flex: 1,
281
+ },
282
+ });
283
+
284
+ export const SwiperPagerView = forwardRef(SwiperPagerViewComponent) as <T>(
285
+ props: SwiperProps<T> & { ref?: React.Ref<SwiperRef> },
286
+ ) => React.ReactElement;
@@ -0,0 +1,146 @@
1
+ import React, { useRef, useState } from "react";
2
+ import { View, Text, StyleSheet, ScrollView, Image, TouchableOpacity } from "react-native";
3
+ import { Swiper } from "@xhs/reds-rn-next";
4
+ import type { SwiperRef } from "@xhs/reds-rn-next";
5
+
6
+ const styles = StyleSheet.create({
7
+ container: {
8
+ paddingBottom: 100,
9
+ },
10
+ swiper: {
11
+ height: 300,
12
+ width: "100%",
13
+ },
14
+ page: {
15
+ flex: 1,
16
+ justifyContent: "center",
17
+ alignItems: "center",
18
+ },
19
+ pageText: {
20
+ fontSize: 24,
21
+ fontWeight: "bold",
22
+ color: "#fff",
23
+ },
24
+ controls: {
25
+ flexDirection: "row",
26
+ justifyContent: "center",
27
+ gap: 10,
28
+ marginTop: 20,
29
+ },
30
+ button: {
31
+ backgroundColor: "#007AFF",
32
+ padding: 10,
33
+ borderRadius: 5,
34
+ },
35
+ buttonText: {
36
+ color: "#fff",
37
+ fontWeight: "600",
38
+ },
39
+ section: {
40
+ marginBottom: 30,
41
+ },
42
+ sectionTitle: {
43
+ fontSize: 16,
44
+ fontWeight: "600",
45
+ marginBottom: 10,
46
+ paddingHorizontal: 16,
47
+ },
48
+ });
49
+
50
+ const colors = ["#FF6B6B", "#4ECDC4", "#45B7D1", "#FFA07A", "#98D8C8"];
51
+
52
+ const images = [
53
+ "https://picasso-static.xiaohongshu.com/fe-platform/c699a29f67e6f8b01355d1b0d30ddbcd35795991.png",
54
+ "https://picasso-static.xiaohongshu.com/fe-platform/84f5deb8733b7f6c04a858162c40632a2777e98d.png",
55
+ "https://picasso-static.xiaohongshu.com/fe-platform/1ea6cde32ec6af0a5886eaf7fd9351cacaaa00dd.png",
56
+ ];
57
+
58
+ export default function SwiperDemo() {
59
+ const [currentPage, setCurrentPage] = useState(0);
60
+ const swiperRef = useRef<SwiperRef>(null);
61
+
62
+ return (
63
+ <ScrollView contentContainerStyle={styles.container}>
64
+ <View style={styles.section}>
65
+ <Text style={styles.sectionTitle}>Basic Swiper</Text>
66
+ <Swiper
67
+ data={colors}
68
+ renderItem={(color, index) => (
69
+ <View style={[styles.page, { backgroundColor: color }]}>
70
+ <Text style={styles.pageText}>Page {index + 1}</Text>
71
+ </View>
72
+ )}
73
+ style={styles.swiper}
74
+ onPageChange={(index) => setCurrentPage(index)}
75
+ />
76
+ <Text style={{ textAlign: "center", marginTop: 10 }}>Current Page: {currentPage + 1}</Text>
77
+ </View>
78
+
79
+ <View style={styles.section}>
80
+ <Text style={styles.sectionTitle}>Infinite Scroll</Text>
81
+ <Swiper
82
+ data={colors.slice(0, 3)}
83
+ renderItem={(color, index) => (
84
+ <View style={[styles.page, { backgroundColor: color }]}>
85
+ <Text style={styles.pageText}>Infinite Page {index + 1}</Text>
86
+ </View>
87
+ )}
88
+ style={styles.swiper}
89
+ infinite={true}
90
+ />
91
+ </View>
92
+
93
+ <View style={styles.section}>
94
+ <Text style={styles.sectionTitle}>With Images</Text>
95
+ <Swiper
96
+ data={images}
97
+ renderItem={(url) => (
98
+ <Image source={{ uri: url }} style={{ width: "100%", height: "100%" }} resizeMode="cover" />
99
+ )}
100
+ style={styles.swiper}
101
+ />
102
+ </View>
103
+
104
+ <View style={styles.section}>
105
+ <Text style={styles.sectionTitle}>Controlled Swiper</Text>
106
+ <Swiper
107
+ ref={swiperRef}
108
+ data={colors}
109
+ renderItem={(color, index) => (
110
+ <View style={[styles.page, { backgroundColor: color }]}>
111
+ <Text style={styles.pageText}>Controlled {index + 1}</Text>
112
+ </View>
113
+ )}
114
+ style={styles.swiper}
115
+ initialPage={1}
116
+ />
117
+ <View style={styles.controls}>
118
+ <TouchableOpacity style={styles.button} onPress={() => swiperRef.current?.prev()}>
119
+ <Text style={styles.buttonText}>Previous</Text>
120
+ </TouchableOpacity>
121
+ <TouchableOpacity style={styles.button} onPress={() => swiperRef.current?.goToPage(0)}>
122
+ <Text style={styles.buttonText}>First</Text>
123
+ </TouchableOpacity>
124
+ <TouchableOpacity style={styles.button} onPress={() => swiperRef.current?.next()}>
125
+ <Text style={styles.buttonText}>Next</Text>
126
+ </TouchableOpacity>
127
+ </View>
128
+ </View>
129
+
130
+ <View style={styles.section}>
131
+ <Text style={styles.sectionTitle}>FlatList Implementation</Text>
132
+ <Swiper
133
+ data={colors}
134
+ renderItem={(color, index) => (
135
+ <View style={[styles.page, { backgroundColor: color }]}>
136
+ <Text style={styles.pageText}>FlatList {index + 1}</Text>
137
+ </View>
138
+ )}
139
+ style={styles.swiper}
140
+ implementation="flatlist"
141
+ infinite={true}
142
+ />
143
+ </View>
144
+ </ScrollView>
145
+ );
146
+ }
@@ -0,0 +1,49 @@
1
+ import BaseDemo from "!!raw-loader!../demo/index.tsx";
2
+
3
+ ## 演示
4
+
5
+ ### 基础用法
6
+
7
+ ::BaseDemo::
8
+
9
+ ## API
10
+
11
+ ### Props
12
+
13
+ | 属性 | 描述 | 类型 | 默认值 |
14
+ | ------------------ | ----------------------------------- | ------------------------------------- | ----------- |
15
+ | data | 数据数组 | T[] | - |
16
+ | renderItem | 渲染每一项的函数 | (item: T, index: number) => ReactNode | - |
17
+ | keyExtractor | 列表项的 key 提取函数 | (item: T, index: number) => string | - |
18
+ | infinite | 是否启用无限/循环滚动 | boolean | false |
19
+ | initialPage | 初始显示的页面索引 | number | 0 |
20
+ | implementation | 实现方式: 'pagerView' 或 'flatlist' | 'pagerView' &#124; 'flatlist' | 'pagerView' |
21
+ | cloneCount | 无限滚动时每端克隆的项数 | number | 2 |
22
+ | lazyMountWindow | 当前页面每侧加载的页面数 | number | 2 |
23
+ | removeClippedPages | 是否卸载远离当前位置的页面 | boolean | false |
24
+ | unmountThreshold | 卸载页面的距离阈值 | number | - |
25
+ | style | 容器样式 | ViewStyle | - |
26
+ | pageMargin | 页面间距 (仅 Android) | number | - |
27
+ | scrollEnabled | 是否可滚动 | boolean | true |
28
+ | overdrag | 允许过度拖拽效果 | boolean | - |
29
+ | offscreenPageLimit | 离屏保留页面数 (仅 Android) | number | - |
30
+ | renderPlaceholder | 未加载页面的占位符组件 | (index: number) => ReactNode | - |
31
+
32
+ ### Events
33
+
34
+ | 事件 | 描述 | 类型 |
35
+ | ------------------------ | -------------------------------- | ----------------------------------------------------------- |
36
+ | onPageChange | 页面切换时触发 | (index: number) => void |
37
+ | onNext | 滑动到下一页时触发 | (index: number) => void |
38
+ | onPrev | 滑动到上一页时触发 | (index: number) => void |
39
+ | onPageScrollStateChanged | 滚动状态变化时触发 | (state: 'idle' &#124; 'dragging' &#124; 'settling') => void |
40
+ | onScrollEndDrag | 用户释放拖拽时触发 (仅 FlatList) | (index: number) => void |
41
+
42
+ ### Ref Methods
43
+
44
+ | 方法 | 描述 | 类型 |
45
+ | -------------- | ---------------- | ------------------------------------------- |
46
+ | goToPage | 跳转到指定页面 | (index: number, animated?: boolean) => void |
47
+ | next | 跳转到下一页 | (animated?: boolean) => void |
48
+ | prev | 跳转到上一页 | (animated?: boolean) => void |
49
+ | getCurrentPage | 获取当前页面索引 | () => number |
@@ -0,0 +1,25 @@
1
+ /**
2
+ * Swiper - A performant, data-driven carousel component
3
+ *
4
+ * @example
5
+ * ```tsx
6
+ * import { Swiper, SwiperRef } from '@/components/Swiper'
7
+ *
8
+ * const swiperRef = useRef<SwiperRef>(null)
9
+ *
10
+ * <Swiper
11
+ * ref={swiperRef}
12
+ * data={items}
13
+ * renderItem={(item, index) => <ItemCard item={item} />}
14
+ * infinite
15
+ * onPageChange={(index) => console.log('Page:', index)}
16
+ * />
17
+ *
18
+ * // Programmatic control
19
+ * swiperRef.current?.next()
20
+ * swiperRef.current?.goToPage(5)
21
+ * ```
22
+ */
23
+
24
+ export { Swiper } from "./Swiper";
25
+ export type { SwiperProps, SwiperRef } from "./types";