@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,7 @@
1
+ import React from "react";
2
+ import type { LazyPageProps } from "./types";
3
+ /**
4
+ * LazyPage component that conditionally mounts/unmounts content
5
+ * based on proximity to current page
6
+ */
7
+ export declare const LazyPage: React.FC<LazyPageProps>;
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ import type { SwiperProps, SwiperRef } from "./types";
3
+ export declare const Swiper: <T>(props: SwiperProps<T> & {
4
+ ref?: React.Ref<SwiperRef>;
5
+ }) => React.ReactElement;
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ import type { SwiperProps, SwiperRef } from "./types";
3
+ export declare const SwiperFlatList: <T>(props: SwiperProps<T> & {
4
+ ref?: React.Ref<SwiperRef>;
5
+ }) => React.ReactElement;
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ import type { SwiperProps, SwiperRef } from "./types";
3
+ export declare const SwiperPagerView: <T>(props: SwiperProps<T> & {
4
+ ref?: React.Ref<SwiperRef>;
5
+ }) => React.ReactElement;
@@ -0,0 +1,24 @@
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
+ export { Swiper } from "./Swiper";
24
+ export type { SwiperProps, SwiperRef } from "./types";
@@ -0,0 +1,166 @@
1
+ import { ReactNode } from "react";
2
+ import { StyleProp, ViewStyle } from "react-native";
3
+ /**
4
+ * Props for the Swiper component
5
+ */
6
+ export interface SwiperProps<T> {
7
+ /** Array of data items to render */
8
+ data: T[];
9
+ /** Function to render each item */
10
+ renderItem: (item: T, index: number) => ReactNode;
11
+ /** Optional key extractor for list items */
12
+ keyExtractor?: (item: T, index: number) => string;
13
+ /** Enable infinite/loop scrolling */
14
+ infinite?: boolean;
15
+ /** Initial page index to display */
16
+ initialPage?: number;
17
+ /**
18
+ * Choose implementation: 'pagerView' or 'flatlist'
19
+ *
20
+ * PagerView (default):
21
+ * - Native ViewPager (Android) / UIPageViewController (iOS)
22
+ * - Smooth 60fps gestures
23
+ * - Better UX for small-medium datasets
24
+ *
25
+ * FlatList:
26
+ * - Built-in virtualization (better for large datasets)
27
+ * - removeClippedSubviews support
28
+ * - More predictable behavior across platforms
29
+ *
30
+ * Default: 'pagerView'
31
+ */
32
+ implementation?: "pagerView" | "flatlist";
33
+ /**
34
+ * Number of items to clone on each end for infinite scroll (default: 2)
35
+ *
36
+ * Can be set larger than array length for maximum buffering.
37
+ * Higher values = smoother fast scrolling, but more memory usage.
38
+ *
39
+ * Examples:
40
+ * - cloneCount=2: Default, good for most cases
41
+ * - cloneCount=5-10: Better for fast scrolling
42
+ * - cloneCount=20+: Maximum buffer for very fast scrolling
43
+ */
44
+ cloneCount?: number;
45
+ /**
46
+ * Number of pages to mount on each side of current page (default: 2)
47
+ *
48
+ * Note: When cloneCount is large, the effective mount window will
49
+ * automatically scale up to prevent blank pages during fast scrolling.
50
+ * Effective window = max(lazyMountWindow, cloneCount/10, capped at 10)
51
+ */
52
+ lazyMountWindow?: number;
53
+ /**
54
+ * Enable aggressive memory management by unmounting pages far from current position
55
+ *
56
+ * When true, pages beyond unmountThreshold will be unmounted to free memory.
57
+ * When false (default), pages stay mounted once loaded for better UX.
58
+ *
59
+ * Recommended: true for large datasets with heavy content (images/videos)
60
+ */
61
+ removeClippedPages?: boolean;
62
+ /**
63
+ * Distance from current page before unmounting (default: lazyMountWindow * 3)
64
+ * Only applies when removeClippedPages is true
65
+ */
66
+ unmountThreshold?: number;
67
+ /** Callback when page changes */
68
+ onPageChange?: (index: number) => void;
69
+ /** Callback when swiping to next page */
70
+ onNext?: (index: number) => void;
71
+ /** Callback when swiping to previous page */
72
+ onPrev?: (index: number) => void;
73
+ /** Callback when scroll state changes */
74
+ onPageScrollStateChanged?: (state: "idle" | "dragging" | "settling") => void;
75
+ /**
76
+ * Callback when user releases drag (before momentum scroll begins)
77
+ *
78
+ * FlatList implementation only.
79
+ * Fires when user lifts finger after dragging, before momentum animation starts.
80
+ * Useful for immediate UI updates (e.g., updating active indicator)
81
+ * while deferring expensive operations (e.g., data fetching) to onPageChange.
82
+ *
83
+ * @param index - The page index where drag ended (real index, not display index)
84
+ *
85
+ * @example
86
+ * <Swiper
87
+ * implementation="flatlist"
88
+ * onScrollEndDrag={(index) => updateActiveIndex(index)} // Fast UI update
89
+ * onPageChange={(index) => fetchData(index)} // Slower data fetch
90
+ * />
91
+ */
92
+ onScrollEndDrag?: (index: number) => void;
93
+ /** Style for the pager container */
94
+ style?: StyleProp<ViewStyle>;
95
+ /** Margin between pages (Android only) */
96
+ pageMargin?: number;
97
+ /** Enable/disable scrolling */
98
+ scrollEnabled?: boolean;
99
+ /** Allow overdrag effect */
100
+ overdrag?: boolean;
101
+ /**
102
+ * Number of pages to keep off-screen on each side (Android only)
103
+ *
104
+ * This is a NATIVE Android API that destroys/recreates views automatically.
105
+ * More efficient than our JS-based removeClippedPages approach.
106
+ *
107
+ * Note: iOS doesn't support this - all pages stay in memory on iOS
108
+ *
109
+ * Examples:
110
+ * - offscreenPageLimit=1: Keep 1 page on each side (3 total in memory)
111
+ * - offscreenPageLimit=2: Keep 2 pages on each side (5 total in memory)
112
+ *
113
+ * Default: Android default is 1, but PagerView doesn't set a default
114
+ */
115
+ offscreenPageLimit?: number;
116
+ /** Custom placeholder component for unmounted pages */
117
+ renderPlaceholder?: (index: number) => ReactNode;
118
+ }
119
+ /**
120
+ * Ref methods exposed by Swiper component
121
+ */
122
+ export interface SwiperRef {
123
+ /** Navigate to specific page */
124
+ goToPage: (index: number, animated?: boolean) => void;
125
+ /** Go to next page */
126
+ next: (animated?: boolean) => void;
127
+ /** Go to previous page */
128
+ prev: (animated?: boolean) => void;
129
+ /** Get current page index */
130
+ getCurrentPage: () => number;
131
+ }
132
+ /**
133
+ * Props for LazyPage component
134
+ */
135
+ export interface LazyPageProps {
136
+ /** Whether this page should be mounted */
137
+ shouldMount: boolean;
138
+ /** Whether this page should be unmounted if far away */
139
+ shouldUnmount?: boolean;
140
+ /** Content to render when mounted */
141
+ children: ReactNode;
142
+ /** Optional placeholder when not mounted */
143
+ placeholder?: ReactNode;
144
+ /** Style for page container */
145
+ style?: StyleProp<ViewStyle>;
146
+ }
147
+ /**
148
+ * Return type for infinite data preparation
149
+ */
150
+ export interface InfiniteDataResult<T> {
151
+ /** Data array with clones added */
152
+ displayData: T[];
153
+ /** Offset where real data starts */
154
+ offset: number;
155
+ /** Number of clones on each side */
156
+ cloneCount: number;
157
+ }
158
+ /**
159
+ * Return type for jump calculation
160
+ */
161
+ export interface JumpResult {
162
+ /** Whether a jump is needed */
163
+ shouldJump: boolean;
164
+ /** Target index to jump to (if shouldJump is true) */
165
+ jumpTo?: number;
166
+ }
@@ -0,0 +1,42 @@
1
+ import type { InfiniteDataResult, JumpResult } from "./types";
2
+ /**
3
+ * Prepare data array for infinite scrolling by cloning boundary items
4
+ *
5
+ * @param data Original data array
6
+ * @param infinite Whether infinite scroll is enabled
7
+ * @param cloneCount Number of items to clone on each end (default: 2)
8
+ * Can exceed data.length - will repeat entire array multiple times
9
+ * @returns Object with displayData (with clones), offset, and cloneCount
10
+ *
11
+ * @example
12
+ * // With data=[A,B,C] and cloneCount=2: [B,C,A,B,C,A,B]
13
+ * // With data=[A,B,C] and cloneCount=5: [A,B,C,A,B,C,A,B,C,A,B]
14
+ */
15
+ export declare function prepareInfiniteData<T>(data: T[], infinite: boolean, cloneCount?: number): InfiniteDataResult<T>;
16
+ /**
17
+ * Calculate if a jump is needed after page change for infinite scroll
18
+ *
19
+ * @param newPage Current display page index
20
+ * @param dataLength Length of original data array
21
+ * @param offset Offset where real data starts
22
+ * @param cloneCount Number of clones on each side
23
+ * @returns Object indicating if jump is needed and target index
24
+ */
25
+ export declare function shouldJumpForInfinite(newPage: number, dataLength: number, offset: number, cloneCount: number): JumpResult;
26
+ /**
27
+ * Convert display index to real data index
28
+ *
29
+ * @param displayIndex Index in the display array (with clones)
30
+ * @param offset Offset where real data starts
31
+ * @param dataLength Length of original data array
32
+ * @returns Real index in original data array
33
+ */
34
+ export declare function getRealIndex(displayIndex: number, offset: number, dataLength: number): number;
35
+ /**
36
+ * Get display index from real data index
37
+ *
38
+ * @param realIndex Index in original data array
39
+ * @param offset Offset where real data starts
40
+ * @returns Display index in display array (with clones)
41
+ */
42
+ export declare function getDisplayIndex(realIndex: number, offset: number): number;
@@ -55,4 +55,5 @@ export * from "./components/SlimAlert";
55
55
  export * from "./components/SlimNavigationBar";
56
56
  export * from "./components/Search";
57
57
  export * from "./components/ActionablePopover";
58
+ export * from "./components/Swiper";
58
59
  import "react-native-url-polyfill/auto";
@@ -1,4 +1,4 @@
1
1
  import React from "react";
2
2
  import { RedsPopover } from "./interface/index";
3
- declare const _default: ({ mode, opacity, content, children, isControl, placement, closeOnClickAgain, trigger, zIndex, visible, onVisibleChange, onClickMask: _onClickMask, popContainerStyle, arrowStyles: propsArrowStyles, offset, duration, animation_duration, hostName, maxWidth, arrowOffset, }: RedsPopover) => React.JSX.Element;
3
+ declare const _default: ({ mode, opacity, content, children, isControl, placement, closeOnClickAgain, trigger, zIndex, visible, onVisibleChange, onClickMask: _onClickMask, popContainerStyle, arrowStyles: propsArrowStyles, offset, duration, hostName, maxWidth, arrowOffset, }: RedsPopover) => React.JSX.Element;
4
4
  export default _default;
@@ -12,7 +12,6 @@ export interface RedsPopover {
12
12
  mode?: "light" | "dark" | "alwaysLight" | "alwaysDark";
13
13
  trigger?: "click" | "touch";
14
14
  duration?: number;
15
- animation_duration?: number;
16
15
  zIndex?: number;
17
16
  popContainerStyle?: ViewStyle;
18
17
  closeOnClickAgain?: boolean;
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ import type { LazyPageProps } from "./types";
3
+ /**
4
+ * LazyPage component that conditionally mounts/unmounts content
5
+ * based on proximity to current page
6
+ */
7
+ export declare const LazyPage: React.FC<LazyPageProps>;
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ import type { SwiperProps, SwiperRef } from "./types";
3
+ export declare const Swiper: <T>(props: SwiperProps<T> & {
4
+ ref?: React.Ref<SwiperRef>;
5
+ }) => React.ReactElement;
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ import type { SwiperProps, SwiperRef } from "./types";
3
+ export declare const SwiperFlatList: <T>(props: SwiperProps<T> & {
4
+ ref?: React.Ref<SwiperRef>;
5
+ }) => React.ReactElement;
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ import type { SwiperProps, SwiperRef } from "./types";
3
+ export declare const SwiperPagerView: <T>(props: SwiperProps<T> & {
4
+ ref?: React.Ref<SwiperRef>;
5
+ }) => React.ReactElement;
@@ -0,0 +1,24 @@
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
+ export { Swiper } from "./Swiper";
24
+ export type { SwiperProps, SwiperRef } from "./types";
@@ -0,0 +1,166 @@
1
+ import { ReactNode } from "react";
2
+ import { StyleProp, ViewStyle } from "react-native";
3
+ /**
4
+ * Props for the Swiper component
5
+ */
6
+ export interface SwiperProps<T> {
7
+ /** Array of data items to render */
8
+ data: T[];
9
+ /** Function to render each item */
10
+ renderItem: (item: T, index: number) => ReactNode;
11
+ /** Optional key extractor for list items */
12
+ keyExtractor?: (item: T, index: number) => string;
13
+ /** Enable infinite/loop scrolling */
14
+ infinite?: boolean;
15
+ /** Initial page index to display */
16
+ initialPage?: number;
17
+ /**
18
+ * Choose implementation: 'pagerView' or 'flatlist'
19
+ *
20
+ * PagerView (default):
21
+ * - Native ViewPager (Android) / UIPageViewController (iOS)
22
+ * - Smooth 60fps gestures
23
+ * - Better UX for small-medium datasets
24
+ *
25
+ * FlatList:
26
+ * - Built-in virtualization (better for large datasets)
27
+ * - removeClippedSubviews support
28
+ * - More predictable behavior across platforms
29
+ *
30
+ * Default: 'pagerView'
31
+ */
32
+ implementation?: "pagerView" | "flatlist";
33
+ /**
34
+ * Number of items to clone on each end for infinite scroll (default: 2)
35
+ *
36
+ * Can be set larger than array length for maximum buffering.
37
+ * Higher values = smoother fast scrolling, but more memory usage.
38
+ *
39
+ * Examples:
40
+ * - cloneCount=2: Default, good for most cases
41
+ * - cloneCount=5-10: Better for fast scrolling
42
+ * - cloneCount=20+: Maximum buffer for very fast scrolling
43
+ */
44
+ cloneCount?: number;
45
+ /**
46
+ * Number of pages to mount on each side of current page (default: 2)
47
+ *
48
+ * Note: When cloneCount is large, the effective mount window will
49
+ * automatically scale up to prevent blank pages during fast scrolling.
50
+ * Effective window = max(lazyMountWindow, cloneCount/10, capped at 10)
51
+ */
52
+ lazyMountWindow?: number;
53
+ /**
54
+ * Enable aggressive memory management by unmounting pages far from current position
55
+ *
56
+ * When true, pages beyond unmountThreshold will be unmounted to free memory.
57
+ * When false (default), pages stay mounted once loaded for better UX.
58
+ *
59
+ * Recommended: true for large datasets with heavy content (images/videos)
60
+ */
61
+ removeClippedPages?: boolean;
62
+ /**
63
+ * Distance from current page before unmounting (default: lazyMountWindow * 3)
64
+ * Only applies when removeClippedPages is true
65
+ */
66
+ unmountThreshold?: number;
67
+ /** Callback when page changes */
68
+ onPageChange?: (index: number) => void;
69
+ /** Callback when swiping to next page */
70
+ onNext?: (index: number) => void;
71
+ /** Callback when swiping to previous page */
72
+ onPrev?: (index: number) => void;
73
+ /** Callback when scroll state changes */
74
+ onPageScrollStateChanged?: (state: "idle" | "dragging" | "settling") => void;
75
+ /**
76
+ * Callback when user releases drag (before momentum scroll begins)
77
+ *
78
+ * FlatList implementation only.
79
+ * Fires when user lifts finger after dragging, before momentum animation starts.
80
+ * Useful for immediate UI updates (e.g., updating active indicator)
81
+ * while deferring expensive operations (e.g., data fetching) to onPageChange.
82
+ *
83
+ * @param index - The page index where drag ended (real index, not display index)
84
+ *
85
+ * @example
86
+ * <Swiper
87
+ * implementation="flatlist"
88
+ * onScrollEndDrag={(index) => updateActiveIndex(index)} // Fast UI update
89
+ * onPageChange={(index) => fetchData(index)} // Slower data fetch
90
+ * />
91
+ */
92
+ onScrollEndDrag?: (index: number) => void;
93
+ /** Style for the pager container */
94
+ style?: StyleProp<ViewStyle>;
95
+ /** Margin between pages (Android only) */
96
+ pageMargin?: number;
97
+ /** Enable/disable scrolling */
98
+ scrollEnabled?: boolean;
99
+ /** Allow overdrag effect */
100
+ overdrag?: boolean;
101
+ /**
102
+ * Number of pages to keep off-screen on each side (Android only)
103
+ *
104
+ * This is a NATIVE Android API that destroys/recreates views automatically.
105
+ * More efficient than our JS-based removeClippedPages approach.
106
+ *
107
+ * Note: iOS doesn't support this - all pages stay in memory on iOS
108
+ *
109
+ * Examples:
110
+ * - offscreenPageLimit=1: Keep 1 page on each side (3 total in memory)
111
+ * - offscreenPageLimit=2: Keep 2 pages on each side (5 total in memory)
112
+ *
113
+ * Default: Android default is 1, but PagerView doesn't set a default
114
+ */
115
+ offscreenPageLimit?: number;
116
+ /** Custom placeholder component for unmounted pages */
117
+ renderPlaceholder?: (index: number) => ReactNode;
118
+ }
119
+ /**
120
+ * Ref methods exposed by Swiper component
121
+ */
122
+ export interface SwiperRef {
123
+ /** Navigate to specific page */
124
+ goToPage: (index: number, animated?: boolean) => void;
125
+ /** Go to next page */
126
+ next: (animated?: boolean) => void;
127
+ /** Go to previous page */
128
+ prev: (animated?: boolean) => void;
129
+ /** Get current page index */
130
+ getCurrentPage: () => number;
131
+ }
132
+ /**
133
+ * Props for LazyPage component
134
+ */
135
+ export interface LazyPageProps {
136
+ /** Whether this page should be mounted */
137
+ shouldMount: boolean;
138
+ /** Whether this page should be unmounted if far away */
139
+ shouldUnmount?: boolean;
140
+ /** Content to render when mounted */
141
+ children: ReactNode;
142
+ /** Optional placeholder when not mounted */
143
+ placeholder?: ReactNode;
144
+ /** Style for page container */
145
+ style?: StyleProp<ViewStyle>;
146
+ }
147
+ /**
148
+ * Return type for infinite data preparation
149
+ */
150
+ export interface InfiniteDataResult<T> {
151
+ /** Data array with clones added */
152
+ displayData: T[];
153
+ /** Offset where real data starts */
154
+ offset: number;
155
+ /** Number of clones on each side */
156
+ cloneCount: number;
157
+ }
158
+ /**
159
+ * Return type for jump calculation
160
+ */
161
+ export interface JumpResult {
162
+ /** Whether a jump is needed */
163
+ shouldJump: boolean;
164
+ /** Target index to jump to (if shouldJump is true) */
165
+ jumpTo?: number;
166
+ }
@@ -0,0 +1,42 @@
1
+ import type { InfiniteDataResult, JumpResult } from "./types";
2
+ /**
3
+ * Prepare data array for infinite scrolling by cloning boundary items
4
+ *
5
+ * @param data Original data array
6
+ * @param infinite Whether infinite scroll is enabled
7
+ * @param cloneCount Number of items to clone on each end (default: 2)
8
+ * Can exceed data.length - will repeat entire array multiple times
9
+ * @returns Object with displayData (with clones), offset, and cloneCount
10
+ *
11
+ * @example
12
+ * // With data=[A,B,C] and cloneCount=2: [B,C,A,B,C,A,B]
13
+ * // With data=[A,B,C] and cloneCount=5: [A,B,C,A,B,C,A,B,C,A,B]
14
+ */
15
+ export declare function prepareInfiniteData<T>(data: T[], infinite: boolean, cloneCount?: number): InfiniteDataResult<T>;
16
+ /**
17
+ * Calculate if a jump is needed after page change for infinite scroll
18
+ *
19
+ * @param newPage Current display page index
20
+ * @param dataLength Length of original data array
21
+ * @param offset Offset where real data starts
22
+ * @param cloneCount Number of clones on each side
23
+ * @returns Object indicating if jump is needed and target index
24
+ */
25
+ export declare function shouldJumpForInfinite(newPage: number, dataLength: number, offset: number, cloneCount: number): JumpResult;
26
+ /**
27
+ * Convert display index to real data index
28
+ *
29
+ * @param displayIndex Index in the display array (with clones)
30
+ * @param offset Offset where real data starts
31
+ * @param dataLength Length of original data array
32
+ * @returns Real index in original data array
33
+ */
34
+ export declare function getRealIndex(displayIndex: number, offset: number, dataLength: number): number;
35
+ /**
36
+ * Get display index from real data index
37
+ *
38
+ * @param realIndex Index in original data array
39
+ * @param offset Offset where real data starts
40
+ * @returns Display index in display array (with clones)
41
+ */
42
+ export declare function getDisplayIndex(realIndex: number, offset: number): number;
@@ -55,4 +55,5 @@ export * from "./components/SlimAlert";
55
55
  export * from "./components/SlimNavigationBar";
56
56
  export * from "./components/Search";
57
57
  export * from "./components/ActionablePopover";
58
+ export * from "./components/Swiper";
58
59
  import "react-native-url-polyfill/auto";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xhsreds/reds-rn-next",
3
- "version": "0.9.1-beta202510291556",
3
+ "version": "0.9.1-feat-swiper202511031535",
4
4
  "author": "贾斌(呀哈) <jiabin@xiaohongshu.com>",
5
5
  "license": "ISC",
6
6
  "dependencies": {
@@ -24,9 +24,10 @@
24
24
  "react": "*",
25
25
  "react-native": "*",
26
26
  "react-native-fs": "2.20.0",
27
+ "react-native-pager-view": ">=6.0.0",
27
28
  "react-native-svg": "13.14.0",
28
29
  "@xhs/react-native-harmony": "*",
29
- "@xhsreds/reds-token-next": "0.9.1-beta202510291556"
30
+ "@xhsreds/reds-token-next": "0.9.0"
30
31
  },
31
32
  "peerDependenciesMeta": {
32
33
  "ozone-schema-web": {
@@ -238,8 +238,8 @@ export const Carousel: React.FC<RedsCarousel> = (props) => {
238
238
 
239
239
  requestAnimationFrame(() => {
240
240
  let scrollOffset = index * offsetPerItem;
241
- // 修复:只有在无限循环模式下才需要减去containerPadding
242
- if (props.playingMode !== "normal" && props.infinite) {
241
+
242
+ if (props.playingMode !== "normal") {
243
243
  scrollOffset -= containerPadding;
244
244
  }
245
245
 
@@ -287,18 +287,10 @@ export const Carousel: React.FC<RedsCarousel> = (props) => {
287
287
  props.direction === "horizontal" ? event.nativeEvent.contentOffset.x : event.nativeEvent.contentOffset.y;
288
288
 
289
289
  let index: number;
290
- // 修复:对于非无限循环的compact模式,需要调整偏移量计算
291
290
  if (props.playingMode === "normal") {
292
291
  index = Math.round(offset / offsetPerItem);
293
292
  } else {
294
- // 对于compact和card模式
295
- if (!props.infinite) {
296
- // 非无限循环模式:不需要加containerPadding,因为滚动时已经考虑了padding
297
- index = Math.round(offset / offsetPerItem);
298
- } else {
299
- // 无限循环模式:需要加containerPadding
300
- index = Math.round((offset + containerPadding) / offsetPerItem);
301
- }
293
+ index = Math.round((offset + containerPadding) / offsetPerItem);
302
294
  }
303
295
 
304
296
  index = Math.max(0, Math.min(index, extendedData.length - 1));
@@ -320,10 +312,6 @@ export const Carousel: React.FC<RedsCarousel> = (props) => {
320
312
  const clampedIndex = Math.max(0, Math.min(index, length - 1));
321
313
  setCurrentIndex(clampedIndex);
322
314
  setRealIndex(clampedIndex);
323
- // 修复:确保滚动到正确位置
324
- if (props.playingMode !== "normal") {
325
- scrollToIndex(clampedIndex, true);
326
- }
327
315
  }
328
316
 
329
317
  setIsScrolling(false);
@@ -1,6 +1,6 @@
1
1
  import React, { useState } from "react";
2
2
  import { View, Text, StyleSheet, ScrollView, Image as RNImage } from "react-native";
3
- import { Carousel, CarouselType } from "@xhs/reds-rn-next";
3
+ import { Carousel } from "@xhs/reds-rn-next";
4
4
  const styles = StyleSheet.create({
5
5
  container: {
6
6
  paddingBottom: 100,
@@ -54,18 +54,6 @@ export default function App() {
54
54
  handlable={false}
55
55
  />
56
56
  <Carousel
57
- data={images}
58
- autoPlay={false}
59
- currentIndex={3}
60
- onChange={handleChange}
61
- onClick={handleClick}
62
- displayNumbers={true}
63
- // duration={3000}
64
- playingMode={CarouselType.PLAYINGMODE.COMPACT}
65
- handlable={true}
66
- infinite={false}
67
- />
68
- {/* <Carousel
69
57
  autoPlay={true}
70
58
  currentIndex={3}
71
59
  onChange={handleChange}
@@ -94,7 +82,7 @@ export default function App() {
94
82
  {images.map((item, idx) => (
95
83
  <RNImage style={{ width: 300, height: 200 }} source={{ uri: item }} />
96
84
  ))}
97
- </Carousel> */}
85
+ </Carousel>
98
86
  {/* <Desc>自动播放(默认轮播间隔1000ms)</Desc>
99
87
  <Carousel data={images} duration={3000} />
100
88