Skip to content
Snippets Groups Projects
stats.js 2.64 KiB
Newer Older
import React, { Component } from 'react'
import {
import styles from '../styles/index'
import cycleModule from '../lib/cycle'
import {getCycleLengthStats as getCycleInfo} from '../lib/cycle-length'
import {stats as labels} from '../i18n/en/labels'
Julia Friesel's avatar
Julia Friesel committed
import AppText from './app-text'

export default class Stats extends Component {
  render() {
    const cycleLengths = cycleModule().getAllCycleLengths()
    const atLeastOneCycle = cycleLengths.length >= 1
    let numberOfCycles
    let cycleInfo
    if (atLeastOneCycle) {
      numberOfCycles = cycleLengths.length
      if (numberOfCycles > 1) {
        cycleInfo = getCycleInfo(cycleLengths)
      }
    }
tina's avatar
tina committed
        <View style={[styles.textWrappingView]}>
          <AppText style={styles.title}>{labels.cycleLengthTitle}</AppText>
          <AppText style={styles.paragraph}>{labels.cycleLengthExplainer}</AppText>
          {!atLeastOneCycle &&
tina's avatar
tina committed
            <AppText>{labels.emptyStats}</AppText>
          }
          {atLeastOneCycle && numberOfCycles === 1 &&
tina's avatar
tina committed
            <AppText>
              {labels.oneCycleStats}
tina's avatar
tina committed
              <AppText style={styles.emphasis}> {cycleLengths[0]} </AppText>
tina's avatar
tina committed
              {labels.daysLabel + '.'}
          }
          {atLeastOneCycle && numberOfCycles > 1 && <View>
            <View style={styles.statsRow}>
tina's avatar
tina committed
              <AppText style={[styles.statsLabelLeft, styles.emphasis]}>{labels.averageLabel}</AppText>
              <AppText style={[styles.statsLabelRight, styles.emphasis]}>{cycleInfo.mean + ' ' + labels.daysLabel}</AppText>
            </View>
            <View style={styles.statsRow}>
              <AppText style={styles.statsLabelLeft}>{labels.minLabel}</AppText>
              <AppText style={styles.statsLabelRight}>{cycleInfo.minimum + ' ' + labels.daysLabel}</AppText>
            </View>
            <View style={styles.statsRow}>
              <AppText style={styles.statsLabelLeft}>{labels.maxLabel}</AppText>
              <AppText style={styles.statsLabelRight}>{cycleInfo.maximum + ' ' + labels.daysLabel}</AppText>
tina's avatar
tina committed
            <View style={[styles.statsRow, styles.paragraph]}>
              <AppText style={styles.statsLabelLeft}>{labels.stdLabel}</AppText>
              <AppText style={styles.statsLabelRight}>{cycleInfo.stdDeviation + ' ' + labels.daysLabel}</AppText>
tina's avatar
tina committed
            <AppText>
              {labels.basisOfStatsBeginning}
tina's avatar
tina committed
              <AppText style={styles.emphasis}> {numberOfCycles} </AppText>
tina's avatar
tina committed
              {labels.basisOfStatsEnd}
            </AppText>
          </View>}