Skip to content
Snippets Groups Projects
pain.js 2.6 KiB
Newer Older
import React, { Component } from 'react'
import {
} from 'react-native'
import { saveSymptom } from '../../../db'
Julia Friesel's avatar
Julia Friesel committed
import { pain as labels } from '../labels'
import ActionButtonFooter from './action-button-footer'
import SelectBoxGroup from '../select-box-group'
Julia Friesel's avatar
Julia Friesel committed
import SymptomSection from './symptom-section'
Julia Friesel's avatar
Julia Friesel committed
import styles from '../../../styles'
Julia Friesel's avatar
Julia Friesel committed
const categories = labels.categories
const boxes = [{
Julia Friesel's avatar
Julia Friesel committed
  label: categories.cramps,
  stateKey: 'cramps'
}, {
Julia Friesel's avatar
Julia Friesel committed
  label: categories.ovulationPain,
  stateKey: 'ovulationPain'
}, {
Julia Friesel's avatar
Julia Friesel committed
  label: categories.headache,
  stateKey: 'headache'
}, {
Julia Friesel's avatar
Julia Friesel committed
  label: categories.backache,
  stateKey: 'backache'
}, {
Julia Friesel's avatar
Julia Friesel committed
  label: categories.nausea,
  stateKey: 'nausea'
}, {
Julia Friesel's avatar
Julia Friesel committed
  label: categories.tenderBreasts,
  stateKey: 'tenderBreasts'
}, {
Julia Friesel's avatar
Julia Friesel committed
  label: categories.migraine,
  stateKey: 'migraine'
}, {
Julia Friesel's avatar
Julia Friesel committed
  label: categories.other,
  stateKey: 'other'
}]

export default class Pain extends Component {
  constructor(props) {
    super(props)
    this.cycleDay = props.cycleDay
    this.state = {}
    if (this.cycleDay.pain !== null ) {
      Object.assign(this.state, this.cycleDay.pain)
      if (this.cycleDay.pain && this.cycleDay.pain.note) {
        this.state.other = true
      }
  toggleState = (key) => {
    const curr = this.state[key]
    this.setState({[key]: !curr})
    if (key === 'other' && !curr) {
      this.setState({focusTextArea: true})
    }
  }

  render() {
    return (
Julia Friesel's avatar
Julia Friesel committed
        <ScrollView style={styles.page}>
Julia Friesel's avatar
Julia Friesel committed
          <SymptomSection
            explainer={labels.explainer}
          >
            <SelectBoxGroup
              data={boxes}
              onSelect={this.toggleState}
              optionsState={this.state}
            />
            { this.state.other &&
              <TextInput
                autoFocus={this.state.focusTextArea}
                multiline={true}
                placeholder="Enter"
                value={this.state.note}
                onChangeText={(val) => {
                  this.setState({note: val})
                }}
              />
            }
Julia Friesel's avatar
Julia Friesel committed
          </SymptomSection>
        </ScrollView>
        <ActionButtonFooter
          symptom='pain'
          cycleDay={this.cycleDay}
          saveAction={() => {
            const copyOfState = Object.assign({}, this.state)
            if (!copyOfState.other) {
              copyOfState.note = null
            saveSymptom('pain', this.cycleDay, copyOfState)
          }}
          saveDisabled={Object.values(this.state).every(value => !value)}
          navigate={this.props.navigate}
        />