import realm from 'realm' let db let cycleDaysSortedbyTempValueView = [] let bleedingDaysSortedByDate = [] const TemperatureSchema = { name: 'Temperature', properties: { value: 'double', exclude: 'bool' } } const BleedingSchema = { name: 'Bleeding', properties: { value: 'int', exclude: 'bool' } } const CycleDaySchema = { name: 'CycleDay', primaryKey: 'date', properties: { date: 'string', temperature: { type: 'Temperature', optional: true }, bleeding: { type: 'Bleeding', optional: true } } } async function openDatabase() { db = await realm.open({ schema: [ CycleDaySchema, TemperatureSchema, BleedingSchema ], // we only want this in dev mode deleteRealmIfMigrationNeeded: true }) // just for testing purposes, the highest temperature will be topmost // because I was too layz to make a scroll view cycleDaysSortedbyTempValueView = db.objects('CycleDay').filtered('temperature != null').sorted('temperature.value', true) bleedingDaysSortedByDate = db.objects('CycleDay').filtered('bleeding != null').sorted('date', true) } function saveTemperature(date, temperature) { db.write(() => { const doc = { date, temperature } db.create('CycleDay', doc) }) } 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 }) }) } return result } export { cycleDaysSortedbyTempValueView, openDatabase, saveTemperature, saveBleeding, getOrCreateCycleDay, bleedingDaysSortedByDate }