Turn symptom buttons into footer component
This commit is contained in:
@@ -0,0 +1,54 @@
|
|||||||
|
import React, { Component } from 'react'
|
||||||
|
import {
|
||||||
|
View,
|
||||||
|
Button,
|
||||||
|
} from 'react-native'
|
||||||
|
import { saveSymptom } from '../../../db'
|
||||||
|
import styles from '../../../styles'
|
||||||
|
|
||||||
|
export default class ActionButtonFooter extends Component {
|
||||||
|
render() {
|
||||||
|
const { symptom, cycleDay, saveAction, saveDisabled, navigate} = this.props
|
||||||
|
const navigateToOverView = () => navigate('CycleDay', cycleDay)
|
||||||
|
const buttons = [
|
||||||
|
{
|
||||||
|
title: 'Cancel',
|
||||||
|
action: () => navigateToOverView()
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Delete',
|
||||||
|
action: () => {
|
||||||
|
saveSymptom(symptom, cycleDay)
|
||||||
|
navigateToOverView()
|
||||||
|
},
|
||||||
|
disabledCondition: !cycleDay[symptom]
|
||||||
|
}, {
|
||||||
|
title: 'Save',
|
||||||
|
action: () => {
|
||||||
|
saveAction()
|
||||||
|
navigateToOverView()
|
||||||
|
},
|
||||||
|
disabledCondition: saveDisabled
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
return (
|
||||||
|
<View style={styles.actionButtonRow}>
|
||||||
|
{buttons.map(({ title, action, disabledCondition }, i) => {
|
||||||
|
const style = { flex: 1, marginHorizontal: 10 }
|
||||||
|
if (i === 0) style.marginLeft = 0
|
||||||
|
if (i === buttons.length - 1) style.marginRight = 0
|
||||||
|
return (
|
||||||
|
<View style={style} key={i}>
|
||||||
|
<Button
|
||||||
|
onPress={action}
|
||||||
|
disabled={disabledCondition}
|
||||||
|
title={title}>
|
||||||
|
</Button>
|
||||||
|
</View >
|
||||||
|
)
|
||||||
|
})}
|
||||||
|
</View>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user