@quidone/react-native-wheel-picker
v1.3.2
Published
Picker is a UI component for selecting an item from a list of options.
Downloads
10,865
Maintainers
Readme
React Native Wheel Picker
A flexible React Native Wheel Picker for iOS and Android without using the native side.
Features
- Without native side.
- Unified API.
- Only native animations.
- Support native feedback.
- Support virtualization.
- Compatible with Expo (Snack).
- Deep customization
- Written
TypeScript
.
Installation
yarn add @quidone/react-native-wheel-picker
Navigation
Usage
🚀 Expo Snack example
If you want to see more examples and experiment, run the examples locally.
git clone [email protected]:quidone/react-native-wheel-picker.git
cd react-native-wheel-picker
yarn install
cd example && yarn install && yarn ios
Simple case
import React, {useState} from 'react';
import WheelPicker from '@quidone/react-native-wheel-picker';
const data = [...Array(100).keys()].map((index) => ({
value: index,
label: index.toString(),
}))
const App = () => {
const [value, setValue] = useState(0);
return (
<WheelPicker
data={data}
value={value}
onValueChanged={({item: {value}}) => setValue(value)}
/>
);
};
export default App;
Native Feedback
You can trigger native sound and impact with @quidone/react-native-wheel-picker-feedback and onValueChanging event
// ...
import WheelPickerFeedback from '@quidone/react-native-wheel-picker-feedback';
const App = () => {
return (
<WheelPicker
onValueChanging={() => {
WheelPickerFeedback.triggerSoundAndImpact();
}}
/>
);
};
API
WheelPicker
Props
data
[array] - items of pickervalue?
[any] - current value of picker itemitemHeight?
[number] - height of picker item in the center.visibleItemCount?
[number] - number of displayed items: 1, 3, 5... (default = 5). For 5, the WheelPicker height is calculated incorrectly, left for backward compatibility.width?
[number | string] - width of picker.readOnly?
[boolean] - read only mode.onValueChanging?
[function] - An event that is triggered when the value is changing.onValueChanged?
[function] - An event that is triggered when the value is changed (wheel is stopped and no touch).keyExtractor?
[function] - key extractor from picker item.renderItem?
[function] - render picker item content.renderItemContainer?
[function] - render picker item container (there is animated container).renderOverlay?
[function | null] - render overlay over the picker.renderList?
[function] - render list (Advanced, It is not recommended to use).style?
[object | array] - root style.itemTextStyle?
[object | array] - item text style for picker item.overlayItemStyle?
[object | array] - style for the overlay element in the centercontentContainerStyle?
[object | array] - style which wraps all of the child views originalscrollEventThrottle?
[object | array] - original
usePickerItemHeight
This hook returns the item height which was passed via props.
useScrollContentOffset
This hook returns the animated value of the ScrollView offset.
withVirtualized
This HOC returns virtualized picker
import WheelPicker, {withVirtualized} from '@quidone/react-native-wheel-picker';
const VirtualizedWheelPicker = withVirtualized(WheelPicker);
Additional props
initialNumToRender?
(default =Math.ceil(visibleItemCount / 2)
) - original.maxToRenderPerBatch?
(default =Math.ceil(visibleItemCount / 2)
) - original.windowSize?
- original.updateCellsBatchingPeriod?
(default = 10) - original.
👨💻 Author
🎯 Was it helpful?
Do you like it and find it helpful? You can help this project in the following way:
- ⭐ Put the star.
- 💡 Suggest your ideas.
- 😉 Open a founded issue.
🤝 Contributing
See the contributing guide to learn how to contribute to the repository and the development workflow.
📄 License
Quidone React Native Wheel Picker is MIT licensed, as found in the LICENSE file.
Made with create-react-native-library