An interactive rating component for React Native that can display ratings using stars, hearts, emojis, or custom symbols.
npm install @kolking/react-native-ratingAn interactive rating component for React Native, which can display ratings using stars, hearts, emojis, or custom symbols of your choice. The component leverages the PanResponder and Animated APIs to create high-performing animations. It is written in TypeScript and has zero dependencies. Whether you’re building a review-based app, a rating system, or any application that requires user feedback, React Native Rating will be an invaluable addition to your toolkit.
``sh`
yarn add @kolking/react-native-rating
`sh`
npm i @kolking/react-native-rating
`jsx
import React, { useCallback, useState } from 'react';
import { StyleSheet, Text, View } from 'react-native';
import { Rating } from '@kolking/react-native-rating';
const App = () => {
const [rating, setRating] = useState(0);
const handleChange = useCallback(
(value: number) => setRating(Math.round((rating + value) * 5) / 10),
[rating],
);
return (
);
};
const styles = StyleSheet.create({
root: {
flex: 1,
alignItems: 'center',
justifyContent: 'center',
},
text: {
fontSize: 17,
marginTop: 20,
},
});
export default App;
`
Prop | Type | Default | Description
---|---|---|---
variant | Variants | stars | Pre-defined design variant, see variants section belowrating | number | 0 | Decimal rating valuesize | number | 30 | Width and height of the rating symbolscale | number | 1.3 | Scaling factor for the snap animation, set it to 1 to turn animation offspacing | number | size * (scale - 1) | Distance between symbols, calculated based on the scale prop if no value is providedmaxRating | number | 5 | Maximum rating value and the total number of symbolsdisabled | boolean | false | Set true to disable user interactionbaseColor | string | variant default | Color of the "empty" symbolsfillColor | string | variant default | Color of the "filled" symbolstouchColor | string | variant default | Color of the symbols during interactionbaseSymbol | SymbolSource | variant default | An image (or array of images) for the "empty" ratingfillSymbol | SymbolSource | variant default | An image (or array of images) for the "filled" ratingstyle | ViewStyle | | Style object applied to the wrapping ViewonMove | (rating: number) => void | | A function called during pan gestureonChange | (rating: number) => void | | A function called when touch released
When rendering a lot of rating components on the same screen, e.g. in a FlatList or SectionList, make sure to set the disabled prop to true. Otherwise you may encounter the "excessive number of pending callbacks" warning.
To achieve a customized appearance for the component, you have the flexibility to define your own symbols using the baseSymbol and fillSymbol props. The SymbolSource type is defined as ImageSourcePropType | ImageSourcePropType[], allowing you to pass either a single image source or an array of images. It is important to note that when passing an array, its length must match the maxRating value to ensure proper functionality.
There are five pre-defined design variants available for selection. All of the variants are designed to support both light and dark color schemes. In addition, you have the flexibility to override any of the variant props with your own custom values.
Preview | baseSymbol | fillSymbol | baseColor | fillColor | touchColor#D1D1D6
---|:-:|:-:|---|---|--- |
|
|
light#3A3A3C dark | #FF9500 light#FF9F0A dark | #FF3B30 light#FF453A dark
Preview | baseSymbol | fillSymbol | baseColor | fillColor | touchColor#C7C7CC
---|:-:|:-:|---|---|--- |
|
|
light#48484A dark | #FF9500 light#FF9F0A dark | #FF3B30 light#FF453A dark
Preview | baseSymbol | fillSymbol | baseColor | fillColor | touchColor#D1D1D6
---|:-:|:-:|---|---|--- |
|
|
light#3A3A3C dark | #FF2D55 light#FF375F dark | #D70015 light#D70015 dark
Preview | baseSymbol | fillSymbol | baseColor | fillColor | touchColor#C7C7CC
---|:-:|:-:|---|---|--- |
|
|
light#48484A dark | #FF2D55 light#FF375F dark | #D70015 light#D70015 dark
Preview | baseSymbol`
---|--- |
I appreciate your feedback, so please star the repository if you like it. This is the best motivation for me to maintain the package and add new features. If you have any feature requests, found a bug, or have ideas for improvement, feel free to open an issue.
Also, please check out my other React Native components that might be a good fit for your project:
- React Native Avatar - Display user avatars like a pro.
- React Native Page Indicator - Show the current page of a swiper, slideshow, carousel, etc.
- React Native Parallax Swiper - Build a horizontal scroll swiper with a parallax effect.
- React Native Crossfade Image - Update image source with crossfade transition effect.
Licensed under the MIT license.