import AbstractService from './abstractService' import TaskModel from '@/models/task' import type {ITask} from '@/modelTypes/ITask' import AttachmentService from './attachment' import LabelService from './label' import {formatISO} from 'date-fns' import {colorFromHex} from '@/helpers/color/colorFromHex' const parseDate = date => { if (date) { return formatISO(new Date(date)) } return null } export default class TaskService extends AbstractService { constructor() { super({ create: '/lists/{listId}', getAll: '/tasks/all', get: '/tasks/{id}', update: '/tasks/{id}', delete: '/tasks/{id}', }) } modelFactory(data) { return new TaskModel(data) } beforeUpdate(model) { return this.processModel(model) } beforeCreate(model) { return this.processModel(model) } processModel(updatedModel) { const model = { ...updatedModel } model.title = model.title?.trim() // Ensure that listId is an int model.listId = Number(model.listId) // Convert dates into an iso string model.dueDate = parseDate(model.dueDate) model.startDate = parseDate(model.startDate) model.endDate = parseDate(model.endDate) model.doneAt = parseDate(model.doneAt) model.created = formatISO(new Date(model.created)) model.updated = formatISO(new Date(model.updated)) // 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 if (model.reminderDates.length > 0) { model.reminderDates = model.reminderDates.map(r => { return formatISO(new Date(r)) }) } // Make the repeating amount to seconds let repeatAfterSeconds = 0 if (model.repeatAfter !== null && (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 model.hexColor = colorFromHex(model.hexColor) // Do the same for all related tasks Object.keys(model.relatedTasks).forEach(relationKind => { model.relatedTasks[relationKind] = model.relatedTasks[relationKind].map(t => { return this.processModel(t) }) }) // Process all attachments to preven parsing errors if (model.attachments.length > 0) { const attachmentService = new AttachmentService() model.attachments.map(a => { return attachmentService.processModel(a) }) } // Preprocess all labels if (model.labels.length > 0) { const labelService = new LabelService() model.labels = model.labels.map(l => labelService.processModel(l)) } return model as ITask } }