2019-03-02 11:25:10 +01:00
|
|
|
import AbstractService from './abstractService'
|
|
|
|
import TaskModel from '../models/task'
|
2020-01-30 21:49:00 +01:00
|
|
|
import AttachmentService from './attachment'
|
2019-03-02 11:25:10 +01:00
|
|
|
|
|
|
|
export default class TaskService extends AbstractService {
|
|
|
|
constructor() {
|
|
|
|
super({
|
|
|
|
create: '/lists/{listID}',
|
2019-03-10 13:59:17 +01:00
|
|
|
getAll: '/tasks/all',
|
2019-11-24 14:16:24 +01:00
|
|
|
get: '/tasks/{id}',
|
2019-03-02 11:25:10 +01:00
|
|
|
update: '/tasks/{id}',
|
|
|
|
delete: '/tasks/{id}',
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
modelFactory(data) {
|
|
|
|
return new TaskModel(data)
|
|
|
|
}
|
|
|
|
|
|
|
|
beforeUpdate(model) {
|
2019-04-29 23:41:39 +02:00
|
|
|
return this.processModel(model)
|
|
|
|
}
|
|
|
|
|
|
|
|
beforeCreate(model) {
|
|
|
|
return this.processModel(model)
|
|
|
|
}
|
|
|
|
|
|
|
|
processModel(model) {
|
|
|
|
// Ensure the listID is an int
|
|
|
|
model.listID = Number(model.listID)
|
|
|
|
|
2019-03-02 11:25:10 +01:00
|
|
|
// Convert the date in a unix timestamp
|
2019-06-05 19:36:32 +02:00
|
|
|
model.dueDate = model.dueDate !== null ? Math.round(+new Date(model.dueDate) / 1000) : model.dueDate
|
|
|
|
model.startDate = model.startDate !== null ? Math.round(+new Date(model.startDate) / 1000): model.startDate
|
|
|
|
model.endDate = model.endDate !== null ? Math.round(+new Date(model.endDate) / 1000) : model.endDate
|
2019-03-02 11:25:10 +01:00
|
|
|
|
|
|
|
// remove all nulls, these would create empty reminders
|
|
|
|
for (const index in model.reminderDates) {
|
|
|
|
if (model.reminderDates[index] === null) {
|
|
|
|
model.reminderDates.splice(index, 1)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Make normal timestamps from js dates
|
2019-04-29 23:41:39 +02:00
|
|
|
if(model.reminderDates.length > 0) {
|
|
|
|
model.reminderDates = model.reminderDates.map(r => {
|
|
|
|
return Math.round(+new Date(r) / 1000)
|
|
|
|
})
|
|
|
|
}
|
2019-03-02 11:25:10 +01:00
|
|
|
|
|
|
|
// Make the repeating amount to seconds
|
|
|
|
let repeatAfterSeconds = 0
|
|
|
|
if (model.repeatAfter.amount !== null || model.repeatAfter.amount !== 0) {
|
|
|
|
switch (model.repeatAfter.type) {
|
|
|
|
case 'hours':
|
|
|
|
repeatAfterSeconds = model.repeatAfter.amount * 60 * 60
|
|
|
|
break
|
|
|
|
case 'days':
|
|
|
|
repeatAfterSeconds = model.repeatAfter.amount * 60 * 60 * 24
|
|
|
|
break
|
|
|
|
case 'weeks':
|
|
|
|
repeatAfterSeconds = model.repeatAfter.amount * 60 * 60 * 24 * 7
|
|
|
|
break
|
|
|
|
case 'months':
|
|
|
|
repeatAfterSeconds = model.repeatAfter.amount * 60 * 60 * 24 * 30
|
|
|
|
break
|
|
|
|
case 'years':
|
|
|
|
repeatAfterSeconds = model.repeatAfter.amount * 60 * 60 * 24 * 365
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
model.repeatAfter = repeatAfterSeconds
|
|
|
|
|
2019-04-30 22:18:06 +02:00
|
|
|
if (model.hexColor.substring(0, 1) === '#') {
|
|
|
|
model.hexColor = model.hexColor.substring(1, 7)
|
|
|
|
}
|
|
|
|
|
2019-11-24 14:16:24 +01:00
|
|
|
// Do the same for all related tasks
|
|
|
|
Object.keys(model.related_tasks).forEach(relationKind => {
|
|
|
|
model.related_tasks[relationKind] = model.related_tasks[relationKind].map(t => {
|
|
|
|
return this.processModel(t)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2020-01-30 21:49:00 +01:00
|
|
|
// Process all attachments to preven parsing errors
|
|
|
|
if(model.attachments.length > 0) {
|
|
|
|
const attachmentService = new AttachmentService()
|
|
|
|
model.attachments.map(a => {
|
|
|
|
return attachmentService.processModel(a)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2019-03-02 11:25:10 +01:00
|
|
|
return model
|
|
|
|
}
|
|
|
|
}
|