@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.
- package/coverage/.tmp/coverage-10.json +1 -1
- package/coverage/.tmp/coverage-11.json +1 -1
- package/coverage/.tmp/coverage-12.json +1 -1
- package/coverage/.tmp/coverage-16.json +1 -1
- package/coverage/.tmp/coverage-17.json +1 -1
- package/coverage/.tmp/coverage-2.json +1 -1
- package/coverage/.tmp/coverage-21.json +1 -1
- package/coverage/.tmp/coverage-22.json +1 -1
- package/coverage/.tmp/coverage-26.json +1 -1
- package/coverage/.tmp/coverage-27.json +1 -1
- package/coverage/.tmp/coverage-29.json +1 -1
- package/coverage/.tmp/coverage-3.json +1 -1
- package/coverage/.tmp/coverage-30.json +1 -1
- package/coverage/.tmp/coverage-31.json +1 -1
- package/coverage/.tmp/coverage-32.json +1 -1
- package/coverage/.tmp/coverage-33.json +1 -1
- package/coverage/.tmp/coverage-34.json +1 -1
- package/coverage/.tmp/coverage-35.json +1 -1
- package/coverage/.tmp/coverage-36.json +1 -1
- package/coverage/.tmp/coverage-37.json +1 -1
- package/coverage/.tmp/coverage-38.json +1 -1
- package/coverage/.tmp/coverage-39.json +1 -1
- package/coverage/.tmp/coverage-4.json +1 -1
- package/coverage/.tmp/coverage-40.json +1 -1
- package/coverage/.tmp/coverage-41.json +1 -1
- package/coverage/.tmp/coverage-42.json +1 -1
- package/coverage/.tmp/coverage-5.json +1 -1
- package/coverage/.tmp/coverage-7.json +1 -1
- package/coverage/.tmp/coverage-8.json +1 -1
- package/coverage/.tmp/coverage-9.json +1 -1
- package/lib/cjs/_chunks/CwkpVXDI.js.map +1 -1
- package/lib/cjs/_chunks/{DNr-ZG4Y.js → Dn-t7SiM.js} +2 -2
- package/lib/cjs/_chunks/{DNr-ZG4Y.js.map → Dn-t7SiM.js.map} +1 -1
- package/lib/cjs/_chunks/{C9tZEm0t.js → hnLc3Qom.js} +8 -10
- package/lib/cjs/_chunks/{C9tZEm0t.js.map → hnLc3Qom.js.map} +1 -1
- package/lib/cjs/components/ActionSheets/ActionSheets.js +1 -1
- package/lib/cjs/components/ActionSheets/ActionSheetsItem.js +1 -1
- package/lib/cjs/components/ActionSheets/api.js +1 -1
- package/lib/cjs/components/ActionSheets/hooks.js +1 -1
- package/lib/cjs/components/ActionSheets/index.js +1 -1
- package/lib/cjs/components/ActionablePopover/ActionablePopover.js +1 -1
- package/lib/cjs/components/ActionablePopover/index.js +1 -1
- package/lib/cjs/components/Alert/Alert.js +1 -1
- package/lib/cjs/components/Alert/hooks/alert.js +1 -1
- package/lib/cjs/components/Alert/index.js +1 -1
- package/lib/cjs/components/Alert/styles.js +1 -1
- package/lib/cjs/components/Avatar/Avatar.js +1 -1
- package/lib/cjs/components/Avatar/index.js +1 -1
- package/lib/cjs/components/Avatar/styles.js +1 -1
- package/lib/cjs/components/AvatarGroup/AvatarGroup.js +1 -1
- package/lib/cjs/components/AvatarGroup/index.js +1 -1
- package/lib/cjs/components/Badge/Badge.js +1 -1
- package/lib/cjs/components/Badge/index.js +1 -1
- package/lib/cjs/components/Badge/styles.js +1 -1
- package/lib/cjs/components/BottomBar/BottomBar.js +1 -1
- package/lib/cjs/components/BottomBar/index.js +1 -1
- package/lib/cjs/components/Button/Button.js +1 -1
- package/lib/cjs/components/Button/Viewable.js +1 -1
- package/lib/cjs/components/Button/index.js +1 -1
- package/lib/cjs/components/Button/styleMap.js +1 -1
- package/lib/cjs/components/Carousel/Carousel.js +3 -10
- package/lib/cjs/components/Carousel/Carousel.js.map +1 -1
- package/lib/cjs/components/Carousel/index.js +1 -1
- package/lib/cjs/components/CheckBoxGroup/CheckBox.js +1 -1
- package/lib/cjs/components/CheckBoxGroup/CheckBoxGroup.js +1 -1
- package/lib/cjs/components/CheckBoxGroup/index.js +1 -1
- package/lib/cjs/components/CheckBoxGroup/styles.js +1 -1
- package/lib/cjs/components/Collapse/Collapse.js +1 -1
- package/lib/cjs/components/Collapse/Item/Item.js +1 -1
- package/lib/cjs/components/Collapse/Item/styles.js +1 -1
- package/lib/cjs/components/Collapse/index.js +1 -1
- package/lib/cjs/components/ConfigProvider/ConfigProvider.js +1 -1
- package/lib/cjs/components/ConfigProvider/hooks/ConfigCache/ConfigCache.js +1 -1
- package/lib/cjs/components/ConfigProvider/hooks/ConfigCache/index.js +1 -1
- package/lib/cjs/components/ConfigProvider/hooks/themeToken/index.js +1 -1
- package/lib/cjs/components/ConfigProvider/hooks/themeToken/useThemeToken.js +1 -1
- package/lib/cjs/components/ConfigProvider/index.js +1 -1
- package/lib/cjs/components/DatePicker/DatePicker.js +1 -1
- package/lib/cjs/components/DatePicker/api.js +1 -1
- package/lib/cjs/components/DatePicker/index.js +1 -1
- package/lib/cjs/components/Divider/Divider.js +1 -1
- package/lib/cjs/components/Divider/index.js +1 -1
- package/lib/cjs/components/Divider/styles.js +1 -1
- package/lib/cjs/components/DropDown/DropDown.js +1 -1
- package/lib/cjs/components/DropDown/DropDownItem.js +1 -1
- package/lib/cjs/components/DropDown/index.js +1 -1
- package/lib/cjs/components/Empty/Empty.js +1 -1
- package/lib/cjs/components/Empty/index.js +1 -1
- package/lib/cjs/components/Empty/styles.js +1 -1
- package/lib/cjs/components/FAB/FAB.js +1 -1
- package/lib/cjs/components/FAB/index.js +1 -1
- package/lib/cjs/components/Form/Form.js +1 -1
- package/lib/cjs/components/Form/FormItem.js +1 -1
- package/lib/cjs/components/Form/index.js +1 -1
- package/lib/cjs/components/Form/styles.js +1 -1
- package/lib/cjs/components/Image/Image.js +1 -1
- package/lib/cjs/components/Image/Image69.js +1 -1
- package/lib/cjs/components/Image/VisibilitySensor.js +1 -1
- package/lib/cjs/components/Image/hook/index.js +1 -1
- package/lib/cjs/components/Image/index.js +1 -1
- package/lib/cjs/components/Image/utils.js +1 -1
- package/lib/cjs/components/ImagePreview/ImagePreview.js +1 -1
- package/lib/cjs/components/ImagePreview/api.js +1 -1
- package/lib/cjs/components/ImagePreview/index.js +1 -1
- package/lib/cjs/components/LanguageProvider/hooks/useLanguage.js +1 -1
- package/lib/cjs/components/LanguageProvider/index.js +1 -1
- package/lib/cjs/components/List/List.js +1 -1
- package/lib/cjs/components/List/ListItem/ListItem.js +1 -1
- package/lib/cjs/components/List/index.js +1 -1
- package/lib/cjs/components/List/styles.js +1 -1
- package/lib/cjs/components/MiniSnackBar/MiniSnackBar.js +1 -1
- package/lib/cjs/components/MiniSnackBar/index.js +1 -1
- package/lib/cjs/components/MiniSnackBar/styles.js +1 -1
- package/lib/cjs/components/NavigationBar/NavigationBar.js +1 -1
- package/lib/cjs/components/NavigationBar/index.js +1 -1
- package/lib/cjs/components/NavigationBar/styles.js +1 -1
- package/lib/cjs/components/NoticeBar/NoticeBar.js +1 -1
- package/lib/cjs/components/NoticeBar/index.js +1 -1
- package/lib/cjs/components/Picker/Picker.js +1 -1
- package/lib/cjs/components/Picker/api.js +1 -1
- package/lib/cjs/components/Picker/index.js +1 -1
- package/lib/cjs/components/PickerView/PickerView.js +1 -1
- package/lib/cjs/components/PickerView/Wheel.js +1 -1
- package/lib/cjs/components/PickerView/index.js +1 -1
- package/lib/cjs/components/Popover/Popover.js +4 -5
- package/lib/cjs/components/Popover/Popover.js.map +1 -1
- package/lib/cjs/components/Popover/index.js +1 -1
- package/lib/cjs/components/Portal/core/PortalProvider.js +1 -1
- package/lib/cjs/components/Portal/index.js +1 -1
- package/lib/cjs/components/Progress/Progress.js +1 -1
- package/lib/cjs/components/Progress/index.js +1 -1
- package/lib/cjs/components/Progress/styles.js +1 -1
- package/lib/cjs/components/ProgressIndicator/ProgressIndicator.js +1 -1
- package/lib/cjs/components/ProgressIndicator/index.js +1 -1
- package/lib/cjs/components/ProgressIndicator/styles.js +1 -1
- package/lib/cjs/components/PullRefresh/PullRefresh.js +1 -1
- package/lib/cjs/components/PullRefresh/component.js +1 -1
- package/lib/cjs/components/PullRefresh/index.js +1 -1
- package/lib/cjs/components/Radio/Radio.js +8 -2
- package/lib/cjs/components/Radio/Radio.js.map +1 -1
- package/lib/cjs/components/Radio/RadioGroup.js +1 -1
- package/lib/cjs/components/Radio/index.js +8 -2
- package/lib/cjs/components/Radio/index.js.map +1 -1
- package/lib/cjs/components/Radio/styles.js +1 -1
- package/lib/cjs/components/Rate/Rate.js +1 -1
- package/lib/cjs/components/Rate/index.js +1 -1
- package/lib/cjs/components/Result/Result.js +1 -1
- package/lib/cjs/components/Result/index.js +1 -1
- package/lib/cjs/components/Result/styles.js +1 -1
- package/lib/cjs/components/Search/Search.js +1 -1
- package/lib/cjs/components/Search/index.js +1 -1
- package/lib/cjs/components/Search/styles.js +1 -1
- package/lib/cjs/components/SegmentedControl/SegmentedControl.js +1 -1
- package/lib/cjs/components/SegmentedControl/index.js +1 -1
- package/lib/cjs/components/Sheets/AnimatedSheets.js +1 -1
- package/lib/cjs/components/Sheets/Sheets.js +1 -1
- package/lib/cjs/components/Sheets/api.js +1 -1
- package/lib/cjs/components/Sheets/index.js +1 -1
- package/lib/cjs/components/Sheets/styles.js +2 -2
- package/lib/cjs/components/Sheets/styles.js.map +1 -1
- package/lib/cjs/components/Skeleton/Item/SkeletonItem.js +1 -1
- package/lib/cjs/components/Skeleton/Item/SkeletonItem69.js +1 -1
- package/lib/cjs/components/Skeleton/Skeleton.js +1 -1
- package/lib/cjs/components/Skeleton/Skeleton69.js +1 -1
- package/lib/cjs/components/Skeleton/index.js +1 -1
- package/lib/cjs/components/Slider/Slider.js +1 -1
- package/lib/cjs/components/Slider/index.js +1 -1
- package/lib/cjs/components/SlimAlert/Alert.js +1 -1
- package/lib/cjs/components/SlimAlert/AlertContent.js +1 -1
- package/lib/cjs/components/SlimAlert/AlertFooter.js +1 -1
- package/lib/cjs/components/SlimAlert/index.js +1 -1
- package/lib/cjs/components/SlimAlert/styles.js +1 -1
- package/lib/cjs/components/SlimNavigationBar/NavigationBar.js +1 -1
- package/lib/cjs/components/SlimNavigationBar/NavigationBarAction.js +1 -1
- package/lib/cjs/components/SlimNavigationBar/index.js +1 -1
- package/lib/cjs/components/SlimNavigationBar/styles.js +1 -1
- package/lib/cjs/components/SlimSheets/AnimatedSheets.js +1 -1
- package/lib/cjs/components/SlimSheets/AnimatedSheetsAction.js +1 -1
- package/lib/cjs/components/SlimSheets/AnimatedSheetsHeader.js +1 -1
- package/lib/cjs/components/SlimSheets/DragAnimatedSheets.js +1 -1
- package/lib/cjs/components/SlimSheets/index.js +1 -1
- package/lib/cjs/components/SlimTabs/BadgeSlimTabItem.js +1 -1
- package/lib/cjs/components/SlimTabs/SlimTab.js +1 -1
- package/lib/cjs/components/SlimTabs/SlimTabItem.js +1 -1
- package/lib/cjs/components/SlimTabs/SlimTabItemLabel.js +1 -1
- package/lib/cjs/components/SlimTabs/SlimTabItemValue.js +1 -1
- package/lib/cjs/components/SlimTabs/SlimTabList.js +1 -1
- package/lib/cjs/components/SlimTabs/index.js +1 -1
- package/lib/cjs/components/SlimTabs/styles.js +1 -1
- package/lib/cjs/components/SnackBar/SnackBar.js +1 -1
- package/lib/cjs/components/SnackBar/index.js +1 -1
- package/lib/cjs/components/SnackBar/styles.js +1 -1
- package/lib/cjs/components/Stepper/Stepper.js +1 -1
- package/lib/cjs/components/Stepper/index.js +1 -1
- package/lib/cjs/components/Swiper/LazyPage.js +42 -0
- package/lib/cjs/components/Swiper/LazyPage.js.map +1 -0
- package/lib/cjs/components/Swiper/Swiper.js +27 -0
- package/lib/cjs/components/Swiper/Swiper.js.map +1 -0
- package/lib/cjs/components/Swiper/SwiperFlatList.js +227 -0
- package/lib/cjs/components/Swiper/SwiperFlatList.js.map +1 -0
- package/lib/cjs/components/Swiper/SwiperPagerView.js +231 -0
- package/lib/cjs/components/Swiper/SwiperPagerView.js.map +1 -0
- package/lib/cjs/components/Swiper/index.js +16 -0
- package/lib/cjs/components/Swiper/index.js.map +1 -0
- package/lib/cjs/components/Swiper/types.js +3 -0
- package/lib/cjs/components/Swiper/types.js.map +1 -0
- package/lib/cjs/components/Swiper/utils.js +73 -0
- package/lib/cjs/components/Swiper/utils.js.map +1 -0
- package/lib/cjs/components/Switch/Switch.js +1 -1
- package/lib/cjs/components/Switch/index.js +1 -1
- package/lib/cjs/components/Tab/Tabs.js +1 -1
- package/lib/cjs/components/Tab/index.js +1 -1
- package/lib/cjs/components/Tab/styles.js +1 -1
- package/lib/cjs/components/TabBar/TabBar.js +1 -1
- package/lib/cjs/components/TabBar/index.js +1 -1
- package/lib/cjs/components/TabBar/styles.js +1 -1
- package/lib/cjs/components/Tag/Tag.js +1 -1
- package/lib/cjs/components/Tag/index.js +1 -1
- package/lib/cjs/components/Text/Text.js +1 -1
- package/lib/cjs/components/Text/Viewable.js +1 -1
- package/lib/cjs/components/Text/hooks/cloneContainer.js +1 -1
- package/lib/cjs/components/Text/hooks/index.js +1 -1
- package/lib/cjs/components/Text/hooks/loadFontFromFile.js +2 -2
- package/lib/cjs/components/Text/hooks/loadFontFromFile.js.map +1 -1
- package/lib/cjs/components/Text/index.js +1 -1
- package/lib/cjs/components/Text/styles.js +1 -1
- package/lib/cjs/components/TextField/TextField.js +1 -1
- package/lib/cjs/components/TextField/index.js +1 -1
- package/lib/cjs/components/TextField/styles.js +1 -1
- package/lib/cjs/components/TextView/TextView.js +1 -1
- package/lib/cjs/components/TextView/index.js +1 -1
- package/lib/cjs/components/TextView/styles.js +1 -1
- package/lib/cjs/components/Toast/Toast.js +1 -1
- package/lib/cjs/components/Toast/api.js +1 -1
- package/lib/cjs/components/Toast/index.js +1 -1
- package/lib/cjs/components/Toast/styles.js +1 -1
- package/lib/cjs/components/Uploader/Uploader.js +3 -3
- package/lib/cjs/components/Uploader/Uploader.js.map +1 -1
- package/lib/cjs/components/Uploader/index.js +2 -2
- package/lib/cjs/components/Uploader/interface/index.js +2 -2
- package/lib/cjs/components/Uploader/styles.js +2 -2
- package/lib/cjs/components/Uploader/utils.js +1 -1
- package/lib/cjs/index.js +9 -2
- package/lib/cjs/index.js.map +1 -1
- package/lib/cjs/pvCount/pvData.js +1 -0
- package/lib/cjs/pvCount/pvData.js.map +1 -1
- package/lib/esm/_chunks/{CAkwE9ZD.js → CgvIDP0E.js} +8 -10
- package/lib/esm/_chunks/{CAkwE9ZD.js.map → CgvIDP0E.js.map} +1 -1
- package/lib/esm/_chunks/{eYElHgNc.js → DRgGcbc8.js} +2 -2
- package/lib/esm/_chunks/{eYElHgNc.js.map → DRgGcbc8.js.map} +1 -1
- package/lib/esm/_chunks/Da9cW8JG.js.map +1 -1
- package/lib/esm/components/ActionSheets/ActionSheets.js +1 -1
- package/lib/esm/components/ActionSheets/ActionSheetsItem.js +1 -1
- package/lib/esm/components/ActionSheets/api.js +1 -1
- package/lib/esm/components/ActionSheets/hooks.js +1 -1
- package/lib/esm/components/ActionSheets/index.js +1 -1
- package/lib/esm/components/ActionablePopover/ActionablePopover.js +1 -1
- package/lib/esm/components/ActionablePopover/index.js +1 -1
- package/lib/esm/components/Alert/Alert.js +1 -1
- package/lib/esm/components/Alert/hooks/alert.js +1 -1
- package/lib/esm/components/Alert/index.js +1 -1
- package/lib/esm/components/Alert/styles.js +1 -1
- package/lib/esm/components/Avatar/Avatar.js +1 -1
- package/lib/esm/components/Avatar/index.js +1 -1
- package/lib/esm/components/Avatar/styles.js +1 -1
- package/lib/esm/components/AvatarGroup/AvatarGroup.js +1 -1
- package/lib/esm/components/AvatarGroup/index.js +1 -1
- package/lib/esm/components/Badge/Badge.js +1 -1
- package/lib/esm/components/Badge/index.js +1 -1
- package/lib/esm/components/Badge/styles.js +1 -1
- package/lib/esm/components/BottomBar/BottomBar.js +1 -1
- package/lib/esm/components/BottomBar/index.js +1 -1
- package/lib/esm/components/Button/Button.js +1 -1
- package/lib/esm/components/Button/Viewable.js +1 -1
- package/lib/esm/components/Button/index.js +1 -1
- package/lib/esm/components/Button/styleMap.js +1 -1
- package/lib/esm/components/Carousel/Carousel.js +3 -10
- package/lib/esm/components/Carousel/Carousel.js.map +1 -1
- package/lib/esm/components/Carousel/index.js +1 -1
- package/lib/esm/components/CheckBoxGroup/CheckBox.js +1 -1
- package/lib/esm/components/CheckBoxGroup/CheckBoxGroup.js +1 -1
- package/lib/esm/components/CheckBoxGroup/index.js +1 -1
- package/lib/esm/components/CheckBoxGroup/styles.js +1 -1
- package/lib/esm/components/Collapse/Collapse.js +1 -1
- package/lib/esm/components/Collapse/Item/Item.js +1 -1
- package/lib/esm/components/Collapse/Item/styles.js +1 -1
- package/lib/esm/components/Collapse/index.js +1 -1
- package/lib/esm/components/ConfigProvider/ConfigProvider.js +1 -1
- package/lib/esm/components/ConfigProvider/hooks/ConfigCache/ConfigCache.js +1 -1
- package/lib/esm/components/ConfigProvider/hooks/ConfigCache/index.js +1 -1
- package/lib/esm/components/ConfigProvider/hooks/themeToken/index.js +1 -1
- package/lib/esm/components/ConfigProvider/hooks/themeToken/useThemeToken.js +1 -1
- package/lib/esm/components/ConfigProvider/index.js +1 -1
- package/lib/esm/components/DatePicker/DatePicker.js +1 -1
- package/lib/esm/components/DatePicker/api.js +1 -1
- package/lib/esm/components/DatePicker/index.js +1 -1
- package/lib/esm/components/Divider/Divider.js +1 -1
- package/lib/esm/components/Divider/index.js +1 -1
- package/lib/esm/components/Divider/styles.js +1 -1
- package/lib/esm/components/DropDown/DropDown.js +1 -1
- package/lib/esm/components/DropDown/DropDownItem.js +1 -1
- package/lib/esm/components/DropDown/index.js +1 -1
- package/lib/esm/components/Empty/Empty.js +1 -1
- package/lib/esm/components/Empty/index.js +1 -1
- package/lib/esm/components/Empty/styles.js +1 -1
- package/lib/esm/components/FAB/FAB.js +1 -1
- package/lib/esm/components/FAB/index.js +1 -1
- package/lib/esm/components/Form/Form.js +1 -1
- package/lib/esm/components/Form/FormItem.js +1 -1
- package/lib/esm/components/Form/index.js +1 -1
- package/lib/esm/components/Form/styles.js +1 -1
- package/lib/esm/components/Image/Image.js +1 -1
- package/lib/esm/components/Image/Image69.js +1 -1
- package/lib/esm/components/Image/VisibilitySensor.js +1 -1
- package/lib/esm/components/Image/hook/index.js +1 -1
- package/lib/esm/components/Image/index.js +1 -1
- package/lib/esm/components/Image/utils.js +1 -1
- package/lib/esm/components/ImagePreview/ImagePreview.js +1 -1
- package/lib/esm/components/ImagePreview/api.js +1 -1
- package/lib/esm/components/ImagePreview/index.js +1 -1
- package/lib/esm/components/LanguageProvider/hooks/useLanguage.js +1 -1
- package/lib/esm/components/LanguageProvider/index.js +1 -1
- package/lib/esm/components/List/List.js +1 -1
- package/lib/esm/components/List/ListItem/ListItem.js +1 -1
- package/lib/esm/components/List/index.js +1 -1
- package/lib/esm/components/List/styles.js +1 -1
- package/lib/esm/components/MiniSnackBar/MiniSnackBar.js +1 -1
- package/lib/esm/components/MiniSnackBar/index.js +1 -1
- package/lib/esm/components/MiniSnackBar/styles.js +1 -1
- package/lib/esm/components/NavigationBar/NavigationBar.js +1 -1
- package/lib/esm/components/NavigationBar/index.js +1 -1
- package/lib/esm/components/NavigationBar/styles.js +1 -1
- package/lib/esm/components/NoticeBar/NoticeBar.js +1 -1
- package/lib/esm/components/NoticeBar/index.js +1 -1
- package/lib/esm/components/Picker/Picker.js +1 -1
- package/lib/esm/components/Picker/api.js +1 -1
- package/lib/esm/components/Picker/index.js +1 -1
- package/lib/esm/components/PickerView/PickerView.js +1 -1
- package/lib/esm/components/PickerView/Wheel.js +1 -1
- package/lib/esm/components/PickerView/index.js +1 -1
- package/lib/esm/components/Popover/Popover.js +4 -5
- package/lib/esm/components/Popover/Popover.js.map +1 -1
- package/lib/esm/components/Popover/index.js +1 -1
- package/lib/esm/components/Portal/core/PortalProvider.js +1 -1
- package/lib/esm/components/Portal/index.js +1 -1
- package/lib/esm/components/Progress/Progress.js +1 -1
- package/lib/esm/components/Progress/index.js +1 -1
- package/lib/esm/components/Progress/styles.js +1 -1
- package/lib/esm/components/ProgressIndicator/ProgressIndicator.js +1 -1
- package/lib/esm/components/ProgressIndicator/index.js +1 -1
- package/lib/esm/components/ProgressIndicator/styles.js +1 -1
- package/lib/esm/components/PullRefresh/PullRefresh.js +1 -1
- package/lib/esm/components/PullRefresh/component.js +1 -1
- package/lib/esm/components/PullRefresh/index.js +1 -1
- package/lib/esm/components/Radio/Radio.js +8 -2
- package/lib/esm/components/Radio/Radio.js.map +1 -1
- package/lib/esm/components/Radio/RadioGroup.js +1 -1
- package/lib/esm/components/Radio/index.js +8 -2
- package/lib/esm/components/Radio/index.js.map +1 -1
- package/lib/esm/components/Radio/styles.js +1 -1
- package/lib/esm/components/Rate/Rate.js +1 -1
- package/lib/esm/components/Rate/index.js +1 -1
- package/lib/esm/components/Result/Result.js +1 -1
- package/lib/esm/components/Result/index.js +1 -1
- package/lib/esm/components/Result/styles.js +1 -1
- package/lib/esm/components/Search/Search.js +1 -1
- package/lib/esm/components/Search/index.js +1 -1
- package/lib/esm/components/Search/styles.js +1 -1
- package/lib/esm/components/SegmentedControl/SegmentedControl.js +1 -1
- package/lib/esm/components/SegmentedControl/index.js +1 -1
- package/lib/esm/components/Sheets/AnimatedSheets.js +1 -1
- package/lib/esm/components/Sheets/Sheets.js +1 -1
- package/lib/esm/components/Sheets/api.js +1 -1
- package/lib/esm/components/Sheets/index.js +1 -1
- package/lib/esm/components/Sheets/styles.js +2 -2
- package/lib/esm/components/Sheets/styles.js.map +1 -1
- package/lib/esm/components/Skeleton/Item/SkeletonItem.js +1 -1
- package/lib/esm/components/Skeleton/Item/SkeletonItem69.js +1 -1
- package/lib/esm/components/Skeleton/Skeleton.js +1 -1
- package/lib/esm/components/Skeleton/Skeleton69.js +1 -1
- package/lib/esm/components/Skeleton/index.js +1 -1
- package/lib/esm/components/Slider/Slider.js +1 -1
- package/lib/esm/components/Slider/index.js +1 -1
- package/lib/esm/components/SlimAlert/Alert.js +1 -1
- package/lib/esm/components/SlimAlert/AlertContent.js +1 -1
- package/lib/esm/components/SlimAlert/AlertFooter.js +1 -1
- package/lib/esm/components/SlimAlert/index.js +1 -1
- package/lib/esm/components/SlimAlert/styles.js +1 -1
- package/lib/esm/components/SlimNavigationBar/NavigationBar.js +1 -1
- package/lib/esm/components/SlimNavigationBar/NavigationBarAction.js +1 -1
- package/lib/esm/components/SlimNavigationBar/index.js +1 -1
- package/lib/esm/components/SlimNavigationBar/styles.js +1 -1
- package/lib/esm/components/SlimSheets/AnimatedSheets.js +1 -1
- package/lib/esm/components/SlimSheets/AnimatedSheetsAction.js +1 -1
- package/lib/esm/components/SlimSheets/AnimatedSheetsHeader.js +1 -1
- package/lib/esm/components/SlimSheets/DragAnimatedSheets.js +1 -1
- package/lib/esm/components/SlimSheets/index.js +1 -1
- package/lib/esm/components/SlimTabs/BadgeSlimTabItem.js +1 -1
- package/lib/esm/components/SlimTabs/SlimTab.js +1 -1
- package/lib/esm/components/SlimTabs/SlimTabItem.js +1 -1
- package/lib/esm/components/SlimTabs/SlimTabItemLabel.js +1 -1
- package/lib/esm/components/SlimTabs/SlimTabItemValue.js +1 -1
- package/lib/esm/components/SlimTabs/SlimTabList.js +1 -1
- package/lib/esm/components/SlimTabs/index.js +1 -1
- package/lib/esm/components/SlimTabs/styles.js +1 -1
- package/lib/esm/components/SnackBar/SnackBar.js +1 -1
- package/lib/esm/components/SnackBar/index.js +1 -1
- package/lib/esm/components/SnackBar/styles.js +1 -1
- package/lib/esm/components/Stepper/Stepper.js +1 -1
- package/lib/esm/components/Stepper/index.js +1 -1
- package/lib/esm/components/Swiper/LazyPage.js +40 -0
- package/lib/esm/components/Swiper/LazyPage.js.map +1 -0
- package/lib/esm/components/Swiper/Swiper.js +25 -0
- package/lib/esm/components/Swiper/Swiper.js.map +1 -0
- package/lib/esm/components/Swiper/SwiperFlatList.js +225 -0
- package/lib/esm/components/Swiper/SwiperFlatList.js.map +1 -0
- package/lib/esm/components/Swiper/SwiperPagerView.js +229 -0
- package/lib/esm/components/Swiper/SwiperPagerView.js.map +1 -0
- package/lib/esm/components/Swiper/index.js +10 -0
- package/lib/esm/components/Swiper/index.js.map +1 -0
- package/lib/esm/components/Swiper/types.js +2 -0
- package/lib/esm/components/Swiper/types.js.map +1 -0
- package/lib/esm/components/Swiper/utils.js +68 -0
- package/lib/esm/components/Swiper/utils.js.map +1 -0
- package/lib/esm/components/Switch/Switch.js +1 -1
- package/lib/esm/components/Switch/index.js +1 -1
- package/lib/esm/components/Tab/Tabs.js +1 -1
- package/lib/esm/components/Tab/index.js +1 -1
- package/lib/esm/components/Tab/styles.js +1 -1
- package/lib/esm/components/TabBar/TabBar.js +1 -1
- package/lib/esm/components/TabBar/index.js +1 -1
- package/lib/esm/components/TabBar/styles.js +1 -1
- package/lib/esm/components/Tag/Tag.js +1 -1
- package/lib/esm/components/Tag/index.js +1 -1
- package/lib/esm/components/Text/Text.js +1 -1
- package/lib/esm/components/Text/Viewable.js +1 -1
- package/lib/esm/components/Text/hooks/cloneContainer.js +1 -1
- package/lib/esm/components/Text/hooks/index.js +1 -1
- package/lib/esm/components/Text/hooks/loadFontFromFile.js +2 -2
- package/lib/esm/components/Text/hooks/loadFontFromFile.js.map +1 -1
- package/lib/esm/components/Text/index.js +1 -1
- package/lib/esm/components/Text/styles.js +1 -1
- package/lib/esm/components/TextField/TextField.js +1 -1
- package/lib/esm/components/TextField/index.js +1 -1
- package/lib/esm/components/TextField/styles.js +1 -1
- package/lib/esm/components/TextView/TextView.js +1 -1
- package/lib/esm/components/TextView/index.js +1 -1
- package/lib/esm/components/TextView/styles.js +1 -1
- package/lib/esm/components/Toast/Toast.js +1 -1
- package/lib/esm/components/Toast/api.js +1 -1
- package/lib/esm/components/Toast/index.js +1 -1
- package/lib/esm/components/Toast/styles.js +1 -1
- package/lib/esm/components/Uploader/Uploader.js +3 -3
- package/lib/esm/components/Uploader/Uploader.js.map +1 -1
- package/lib/esm/components/Uploader/index.js +2 -2
- package/lib/esm/components/Uploader/interface/index.js +2 -2
- package/lib/esm/components/Uploader/styles.js +2 -2
- package/lib/esm/components/Uploader/utils.js +1 -1
- package/lib/esm/index.js +8 -2
- package/lib/esm/index.js.map +1 -1
- package/lib/esm/pvCount/pvData.js +1 -0
- package/lib/esm/pvCount/pvData.js.map +1 -1
- package/lib/src/components/Popover/Popover.d.ts +1 -1
- package/lib/src/components/Popover/interface/index.d.ts +0 -1
- package/lib/src/components/Swiper/LazyPage.d.ts +7 -0
- package/lib/src/components/Swiper/Swiper.d.ts +5 -0
- package/lib/src/components/Swiper/SwiperFlatList.d.ts +5 -0
- package/lib/src/components/Swiper/SwiperPagerView.d.ts +5 -0
- package/lib/src/components/Swiper/index.d.ts +24 -0
- package/lib/src/components/Swiper/types.d.ts +166 -0
- package/lib/src/components/Swiper/utils.d.ts +42 -0
- package/lib/src/index.d.ts +1 -0
- package/lib/types/components/Popover/Popover.d.ts +1 -1
- package/lib/types/components/Popover/interface/index.d.ts +0 -1
- package/lib/types/components/Swiper/LazyPage.d.ts +7 -0
- package/lib/types/components/Swiper/Swiper.d.ts +5 -0
- package/lib/types/components/Swiper/SwiperFlatList.d.ts +5 -0
- package/lib/types/components/Swiper/SwiperPagerView.d.ts +5 -0
- package/lib/types/components/Swiper/index.d.ts +24 -0
- package/lib/types/components/Swiper/types.d.ts +166 -0
- package/lib/types/components/Swiper/utils.d.ts +42 -0
- package/lib/types/index.d.ts +1 -0
- package/package.json +3 -2
- package/src/components/Carousel/Carousel.tsx +3 -15
- package/src/components/Carousel/demo/index.tsx +2 -14
- package/src/components/Popover/Popover.tsx +3 -4
- package/src/components/Popover/doc/index.mdx +21 -22
- package/src/components/Popover/interface/index.ts +0 -1
- package/src/components/Sheets/styles.ts +2 -2
- package/src/components/Swiper/LazyPage.tsx +44 -0
- package/src/components/Swiper/Swiper.tsx +31 -0
- package/src/components/Swiper/SwiperFlatList.tsx +299 -0
- package/src/components/Swiper/SwiperPagerView.tsx +286 -0
- package/src/components/Swiper/demo/index.tsx +146 -0
- package/src/components/Swiper/doc/index.mdx +49 -0
- package/src/components/Swiper/index.ts +25 -0
- package/src/components/Swiper/types.ts +208 -0
- package/src/components/Swiper/utils.ts +133 -0
- package/src/index.ts +1 -0
|
@@ -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;
|
package/lib/src/index.d.ts
CHANGED
|
@@ -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,
|
|
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;
|
|
@@ -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;
|
package/lib/types/index.d.ts
CHANGED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xhsreds/reds-rn-next",
|
|
3
|
-
"version": "0.9.1-
|
|
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.
|
|
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
|
-
|
|
242
|
-
if (props.playingMode !== "normal"
|
|
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
|
-
|
|
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
|
|
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
|
|