Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/24ark/react-native-step-indicator
A simple react-native implementation of step indicator widget compatible with the ViewPager and ListView.
https://github.com/24ark/react-native-step-indicator
listview progress-view react-native step viewpager
Last synced: 2 days ago
JSON representation
A simple react-native implementation of step indicator widget compatible with the ViewPager and ListView.
- Host: GitHub
- URL: https://github.com/24ark/react-native-step-indicator
- Owner: 24ark
- License: apache-2.0
- Created: 2017-01-20T20:59:40.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2023-02-17T22:43:26.000Z (almost 2 years ago)
- Last Synced: 2025-01-16T22:39:40.474Z (9 days ago)
- Topics: listview, progress-view, react-native, step, viewpager
- Language: TypeScript
- Homepage:
- Size: 5.72 MB
- Stars: 1,445
- Watchers: 10
- Forks: 312
- Open Issues: 85
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-react-native - react-native-step-indicator ★538 - A simple react-native implementation of step indicator widget compatible with the ViewPager and ListView. (Components / UI)
- awesome-reactnative-ui - react-native-step-indicator - native implementation of step indicator widget compatible with the ViewPager and ListView.|<ul><li>Last updated : This week</li><li>Stars : 660</li><li>Open issues : 28</li></ul>|![](https://raw.githubusercontent.com/24ark/react-native-step-indicator/master/art/HorizontalStepIndicator.gif)| (Others)
- awesome-react-native - react-native-step-indicator ★538 - A simple react-native implementation of step indicator widget compatible with the ViewPager and ListView. (Components / UI)
- awesome-reactnative-ui - react-native-step-indicator - native implementation of step indicator widget compatible with the ViewPager and ListView.|<ul><li>Last updated : This week</li><li>Stars : 660</li><li>Open issues : 28</li></ul>|![](https://raw.githubusercontent.com/24ark/react-native-step-indicator/master/art/HorizontalStepIndicator.gif)| (Others)
- awesome-react-native - react-native-step-indicator ★538 - A simple react-native implementation of step indicator widget compatible with the ViewPager and ListView. (Components / UI)
- awesome-react-native-ui - react-native-step-indicator ★62 - A simple react-native implementation of step indicator widget compatible with the ViewPager and ListView. (Components / UI)
- awesome-humanscape - react-native-step-indicator - 현재 진행 상황을 알려주는 Step Indicator 컴포넌트 (React, React Native / Components)
- awesome-react-native - react-native-step-indicator ★538 - A simple react-native implementation of step indicator widget compatible with the ViewPager and ListView. (Components / UI)
README
# react-native-step-indicator
A simple react-native implementation of step indicator widget compatible with the ViewPager and ListView.
Features
- Can be used with ViewPager and Listview
- Custom Styling
- Supports vertical and horizontal orientation
- Supports animation between steps![alt tag](https://raw.githubusercontent.com/24ark/react-native-step-indicator/master/art/HorizontalStepIndicator.gif) ![alt tag](https://raw.githubusercontent.com/24ark/react-native-step-indicator/master/art/VerticalStepIndicator.gif)
[example/src/HorizontalStepIndicator.tsx](example/src/HorizontalStepIndicator.tsx) [example/src/VerticalStepIndicator.tsx](example/src/VerticalStepIndicator.tsx)### Example
```sh
$ yarn
$ yarn example ios // For ios
$ yarn example android // For Android
```### Installation
``npm install react-native-step-indicator --save``or
``yarn add react-native-step-indicator``
### Usage
```javascript
import StepIndicator from 'react-native-step-indicator';const labels = ["Cart","Delivery Address","Order Summary","Payment Method","Track"];
const customStyles = {
stepIndicatorSize: 25,
currentStepIndicatorSize:30,
separatorStrokeWidth: 2,
currentStepStrokeWidth: 3,
stepStrokeCurrentColor: '#fe7013',
stepStrokeWidth: 3,
stepStrokeFinishedColor: '#fe7013',
stepStrokeUnFinishedColor: '#aaaaaa',
separatorFinishedColor: '#fe7013',
separatorUnFinishedColor: '#aaaaaa',
stepIndicatorFinishedColor: '#fe7013',
stepIndicatorUnFinishedColor: '#ffffff',
stepIndicatorCurrentColor: '#ffffff',
stepIndicatorLabelFontSize: 13,
currentStepIndicatorLabelFontSize: 13,
stepIndicatorLabelCurrentColor: '#fe7013',
stepIndicatorLabelFinishedColor: '#ffffff',
stepIndicatorLabelUnFinishedColor: '#aaaaaa',
labelColor: '#999999',
labelSize: 13,
currentStepLabelColor: '#fe7013'
}constructor() {
this.state = {
currentPosition: 0
}
}render() {
return (
)
}onPageChange(position){
this.setState({currentPosition: position});
}
//...
```### Properties
| Name | Type | Description | Default
| ------------ | ------------- | ------------ |------------ |
| `currentPosition` | Number | Current position in steps | 0
| ```stepCount``` | Number | Number of steps | 5
| ```direction``` | String | Orientation(i.e. horizontal,vertical) | horizontal
| ```customStyles``` | Object | Custom styling | {}
| ```labels``` | Array | Labels for each step | null
| `onPress` | Function (position: Number) | Function called when a step is pressed | null
| `renderStepIndicator` | Function (position: Number, stepStatus: String) | Use this to render custom content inside step | null
| `renderLabel` | Function (position: Number, stepStatus: String, label: String, currentPosition: Number) | Use this to render custom label for each step | null### Custom Styles
| Name | Type | Default
| ------------ | ------------ |------------ |
| ```stepIndicatorSize``` | Number | 30
| ```currentStepIndicatorSize``` | Number | 40
| ```separatorStrokeWidth``` | Number | 3
| ```separatorStrokeUnfinishedWidth``` | Number | 0
| ```separatorStrokeFinishedWidth``` | Number | 0
| ```stepStrokeWidth``` | Number | 0
| ```currentStepStrokeWidth``` | Number | 5
| ```stepStrokeCurrentColor``` | String | '#4aae4f'
| ```stepStrokeFinishedColor``` | String | '#4aae4f'
| ```stepStrokeUnFinishedColor``` | String | '#4aae4f'
| ```separatorFinishedColor``` | String | '#4aae4f'
| ```separatorUnFinishedColor``` | String | '#a4d4a5'
| ```stepIndicatorFinishedColor``` | String | '#4aae4f'
| ```stepIndicatorUnFinishedColor``` | String | '#a4d4a5'
| ```stepIndicatorCurrentColor``` | String | '#ffffff'
| ```stepIndicatorLabelFontSize``` | Number | 15
| ```currentStepIndicatorLabelFontSize``` | Number | 15
| ```stepIndicatorLabelCurrentColor``` | String | '#000000'
| ```stepIndicatorLabelFinishedColor``` | String | '#ffffff'
| ```stepIndicatorLabelUnFinishedColor``` | String | 'rgba(255,255,255,0.5)'
| ```labelColor``` | String | '#000000'
| ```currentStepLabelColor``` | String | '#4aae4f'
| ```labelSize``` | Number | 13
| ```labelAlign``` | String | 'center'
| ```labelFontFamily``` | String |### Contributing
If you'd like to see something added or changed to this module please open a new GitHub issue. Pull requests are always welcome.
### License
- [Apache-2.0](https://github.com/24ark/react-native-step-indicator/blob/master/LICENSE). © Arkit Vora