2017-12-14 18:12:14 +00:00
|
|
|
const BaseModel = require('lib/BaseModel.js');
|
|
|
|
const Note = require('lib/models/Note.js');
|
2017-11-27 22:50:46 +00:00
|
|
|
|
|
|
|
class Alarm extends BaseModel {
|
|
|
|
|
|
|
|
static tableName() {
|
|
|
|
return 'alarms';
|
|
|
|
}
|
|
|
|
|
|
|
|
static modelType() {
|
|
|
|
return BaseModel.TYPE_ALARM;
|
|
|
|
}
|
|
|
|
|
|
|
|
static byNoteId(noteId) {
|
|
|
|
return this.modelSelectOne('SELECT * FROM alarms WHERE note_id = ?', [noteId]);
|
|
|
|
}
|
|
|
|
|
2017-11-28 00:22:38 +00:00
|
|
|
static async deleteExpiredAlarms() {
|
|
|
|
return this.db().exec('DELETE FROM alarms WHERE trigger_time <= ?', [Date.now()]);
|
|
|
|
}
|
2017-11-27 22:50:46 +00:00
|
|
|
|
2017-11-28 00:22:38 +00:00
|
|
|
static async alarmIdsWithoutNotes() {
|
2017-11-27 22:50:46 +00:00
|
|
|
// https://stackoverflow.com/a/4967229/561309
|
2017-11-28 00:22:38 +00:00
|
|
|
const alarms = await this.db().selectAll('SELECT alarms.id FROM alarms LEFT JOIN notes ON alarms.note_id = notes.id WHERE notes.id IS NULL');
|
|
|
|
return alarms.map((a) => { return a.id });
|
2017-11-27 22:50:46 +00:00
|
|
|
}
|
|
|
|
|
2017-11-28 20:17:34 +00:00
|
|
|
static async makeNotification(alarm, note = null) {
|
|
|
|
if (!note) note = await Note.load(alarm.note_id);
|
|
|
|
|
|
|
|
const output = {
|
|
|
|
id: alarm.id,
|
|
|
|
date: new Date(note.todo_due),
|
|
|
|
title: note.title.substr(0,128),
|
|
|
|
};
|
|
|
|
|
|
|
|
if (note.body) output.body = note.body.substr(0,512);
|
|
|
|
|
|
|
|
return output;
|
|
|
|
}
|
|
|
|
|
2017-11-28 20:31:14 +00:00
|
|
|
static async allDue() {
|
|
|
|
return this.modelSelectAll('SELECT * FROM alarms WHERE trigger_time >= ?', [Date.now()]);
|
|
|
|
}
|
|
|
|
|
2017-11-27 22:50:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = Alarm;
|