A react native implementation of the package SCLAlertView-Swift
react-native-scl-alert
A pure react native javascript implementation of the package.
Road Map
- [x] Documentation to customize styles
- [ ] Handle orientation
- [x] Default images for header
- [ ] Text Field Component
- [ ] More transitions
Features
- Declarative API
- High customizable UI
- Built in themes inspired on bootstrap
Setup
yarn add react-native-scl-alert
or
npm install --save react-native-scl-alert
Usage
import React from 'react'
import {
View,
Button,
StyleSheet
} from 'react-native'
import {
SCLAlert,
SCLAlertButton
} from 'react-native-scl-alert'
export default class App extends React.Component {
state = {
show: false
}
handleOpen = () => {
this.setState({ show: true })
}
handleClose = () => {
this.setState({ show: false })
}
render() {
return (
<View style={styles.container}>
<Button title="Show" onPress={this.handleOpen} />
<SCLAlert
theme="info"
show={this.state.show}
title="Lorem"
subtitle="Lorem ipsum dolor"
>
<SCLAlertButton theme="info" onPress={this.handleClose}>Done</SCLAlertButton>
</SCLAlert>
</View>
)
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
backgroundColor: '#fff',
alignItems: 'center',
justifyContent: 'center'
}
})
Demo
You can customized the look and feel of this library the way you want, but, if you prefer, we ship 6 themes for you:
default
inverse
success
info
danger
warning
SCLAlert
Name | Type | Default | Description |
---|---|---|---|
show | PropTypes.bool | false | Show the alert |
cancellable | PropTypes.bool | true | If user press in the overlay, will trigger onRequestClose func |
onRequestClose | PropTypes.func | null | Trigger a function asking to close the alert |
slideAnimationDuration | PropTypes.number | 250 | Duration in ms of the alert animation |
overlayStyle | ViewPropTypes.style | {} | Extends the overlay view style |
title | PropTypes.string | REQUIRED | A string to render in the modal title |
titleContainerStyle | ViewPropTypes.style | {} | Extends the title container view style |
titleStyle | Text.propTypes.style | {} | Extends the title text style |
subtitle | PropTypes.string | REQUIRED | A string to render in the modal subtitle |
subtitleContainerStyle | ViewPropTypes.style | {} | Extends the subtitle container view style |
subtitleStyle | Text.propTypes.style | {} | Extends the subtitle text style |
headerContainerStyles | ViewPropTypes.style | {} | Extends the title headerContainer view style |
headerInnerStyles | ViewPropTypes.style | {} | Extends the title headerInner view style |
headerIconComponent | PropTypes.node | null | A component to render inside the header |
children | PropTypes.node | null | Custom content. Put here buttons and text inputs |
SCLAlertButton
Name | Type | Default | Description |
---|---|---|---|
children | PropTypes.string or PropTypes.node | REQUIRED | String or react node |
containerStyle | ViewPropTypes.style | {} | |
textStyle | Text.propTypes.style | {} | |
theme | PropTypes.string | 'default' | Check options above |
onPress | PropTypes.func | REQUIRED | Callback after user press in the button |