Skip to content
Snippets Groups Projects
stats.js 1.78 KiB
Newer Older
import React, { Component } from 'react'
import {
  Text,
import { LocalDate, ChronoUnit } from 'js-joda'
import styles from '../styles/index'
import cycleModule from '../lib/cycle'
import getCycleInfo from '../lib/cycle-length'

export default class Stats extends Component {
  render() {
    const allMensesStarts = cycleModule().getAllMensesStarts()
    const statsText = determineStatsText(allMensesStarts)
        <View>
          <Text style={styles.stats}>{statsText}</Text>
        </View>
}

function getCycleLength(cycleStartDates) {
  for (let i = 0; i < cycleStartDates.length - 1; i++) {
    const nextCycleStart = LocalDate.parse(cycleStartDates[i])
    const cycleStart = LocalDate.parse(cycleStartDates[i + 1])
    cycleLengths.push(cycleStart.until(nextCycleStart, ChronoUnit.DAYS))
}

function determineStatsText(allMensesStarts) {
  const emptyStats = 'At least one completed cycle is needed to present you with stats here.'
  if (allMensesStarts.length < 2) {
    return emptyStats
  } else {
    const cycleLengths = getCycleLength(allMensesStarts)
    const numberOfCycles = cycleLengths.length
    if (numberOfCycles === 1) {
      return `You have documented one cycle of ${cycleLengths[0]} days.`
    const cycleInfo = getCycleInfo(cycleLengths)
    const statsText = `Stats are based on ${numberOfCycles} completed cycles.\n\n\
    Average cycle length: ${cycleInfo.mean} days\n\nShortest cycle: ${cycleInfo.minimum} days\nLongest cycle: ${cycleInfo.maximum} days\nMedian length (meaning 50% of cycles are of this length or shorter): ${cycleInfo.median} days\nStandard deviation: ${cycleInfo.stdDeviation}`
    return statsText