Newer
Older
import realm from 'realm'
let db
let cycleDaysSortedbyDate = []
let bleedingDaysSortedByDate = []
const TemperatureSchema = {
name: 'Temperature',
properties: {
const BleedingSchema = {
name: 'Bleeding',
properties: {
value: 'int',
exclude: 'bool'
}
}
const CycleDaySchema = {
name: 'CycleDay',
primaryKey: 'date',
date: 'string',
temperature: {
type: 'Temperature',
optional: true
},
bleeding: {
type: 'Bleeding',
optional: true
}
}
}
async function openDatabase() {
db = await realm.open({
schema: [
CycleDaySchema,
],
// we only want this in dev mode
deleteRealmIfMigrationNeeded: true
})
cycleDaysSortedbyDate = db.objects('CycleDay').sorted('date', true)
bleedingDaysSortedByDate = db.objects('CycleDay').filtered('bleeding != null').sorted('date', true)
function saveTemperature(cycleDay, temperature) {
cycleDay.temperature = temperature
function saveBleeding(cycleDay, bleeding) {
db.write(() => {
cycleDay.bleeding = bleeding
})
}
function getOrCreateCycleDay(localDate) {
let result = db.objectForPrimaryKey('CycleDay', localDate)
if (!result) {
db.write(() => {
result = db.create('CycleDay', {
date: localDate
function getPreviousTemperature(cycleDay) {
const cycleDayIndex = cycleDaysSortedbyDate.findIndex(day => day === cycleDay)
const previousCycleDays = cycleDaysSortedbyDate.slice(cycleDayIndex + 1)
const winner = previousCycleDays.find(cycleDay => cycleDay.temperature)
if (!winner) return null
return winner.temperature.value
}
cycleDaysSortedbyDate,
bleedingDaysSortedByDate,
getPreviousTemperature