Newer
Older
import { BackHandler, StyleSheet, View } from 'react-native'
import { connect } from 'react-redux'
import { getDate } from '../slices/date'
import { getNavigation, navigate, goBack } from '../slices/navigation'
import Header from './header'
import Menu from './menu'
import { headerTitles } from '../i18n/en/labels'
import setupNotifications from '../lib/notifications'
import { getCycleDay, closeDb } from '../db'
class App extends Component {
static propTypes = {
date: PropTypes.string,
navigation: PropTypes.object.isRequired,
navigate: PropTypes.func,
goBack: PropTypes.func,
this.backHandler = BackHandler.addEventListener(
'hardwareBackPress',
this.goBack
)
setupNotifications(this.props.navigate)
goBack = () => {
const { currentPage } = this.props.navigation
if (currentPage === 'Home') {
closeDb()
BackHandler.exitApp()
} else {
this.props.goBack()
}
return true
}
componentWillUnmount() {
this.backHandler.remove()
render() {
const { date, navigation, goBack } = this.props
const { currentPage } = navigation
const Page = viewsList[currentPage]
const isSettingsSubView = isSettingsView(currentPage)
const isTemperatureEditView = currentPage === 'TemperatureEditView'
const headerProps = {
title,
handleBack: isSettingsSubView ? goBack : null,
}
const pageProps = {
cycleDay: date && getCycleDay(date),
isTemperatureEditView,
<View style={styles.container}>
<Header { ...headerProps } />
const styles = StyleSheet.create({
container: {
flex: 1
}
})
const mapStateToProps = (state) => {
return({
date: getDate(state),
navigation: getNavigation(state)
})
}
const mapDispatchToProps = (dispatch) => {
return({
navigate: (page) => dispatch(navigate(page)),
})
}
export default connect(
mapStateToProps,