Newer
Older
import React, { Component } from 'react'
import { CalendarList } from 'react-native-calendars'
import { getOrCreateCycleDay, bleedingDaysSortedByDate } from '../db'
export default class CalendarView extends Component {
constructor(props) {
super(props)
this.state = {
bleedingDaysInCalFormat: toCalFormat(bleedingDaysSortedByDate)
}
this.setStateWithCalFormattedDays = (function (CalendarComponent) {
return function(_, changes) {
if (Object.values(changes).every(x => x && !x.length)) return
bleedingDaysInCalFormat: toCalFormat(bleedingDaysSortedByDate)
bleedingDaysSortedByDate.addListener(this.setStateWithCalFormattedDays)
bleedingDaysSortedByDate.removeListener(this.setStateWithCalFormattedDays)
const cycleDay = getOrCreateCycleDay(result.dateString)
const navigate = this.props.navigate
render() {
return (
<CalendarList
onDayPress={this.passDateToDayView.bind(this)}
markedDates={this.state.bleedingDaysInCalFormat}
markingType={'period'}
/>
function toCalFormat(bleedingDaysSortedByDate) {
const shadesOfRed = ['#ffbaba', '#ff7b7b', '#ff5252', '#ff0000']
return bleedingDaysSortedByDate.reduce((acc, day) => {
acc[day.date] = {
startingDay: true,
endingDay: true,
color: shadesOfRed[day.bleeding.value]
}
return acc
}, {})
}