From 45579ee2373620917ada72f7612afa00522a56b4 Mon Sep 17 00:00:00 2001 From: konrad Date: Wed, 19 Dec 2018 14:38:21 +0000 Subject: [PATCH] Subtasks (#9) --- src/components/lists/ShowList.vue | 90 +++++++++++++++++++++++++++---- src/vikunja.scss | 14 +++++ todo.md | 4 +- 3 files changed, 97 insertions(+), 11 deletions(-) diff --git a/src/components/lists/ShowList.vue b/src/components/lists/ShowList.vue index 98760b1c..593e6e65 100644 --- a/src/components/lists/ShowList.vue +++ b/src/components/lists/ShowList.vue @@ -9,7 +9,7 @@

- + @@ -63,7 +63,7 @@

- +
@@ -127,6 +127,35 @@
+
+ +
+ +
+
+ +
+
+ + + + +
+
+ @@ -153,11 +182,13 @@ return { listID: this.$route.params.id, list: {}, - newTask: '', + newTask: {text: ''}, error: '', loading: false, isTaskEdit: false, - taskEditTask: {}, + taskEditTask: { + subtasks: [], + }, lastReminder: 0, nowUnix: new Date(), repeatAfter: {type: 'days', amount: null}, @@ -194,8 +225,8 @@ HTTP.get(`lists/` + this.$route.params.id, {headers: {'Authorization': 'Bearer ' + localStorage.getItem('token')}}) .then(response => { - // Make date objects from timestamps for (const t in response.data.tasks) { + // Make date objects from timestamps let dueDate = new Date(response.data.tasks[t].dueDate * 1000) if (dueDate === 0) { response.data.tasks[t].dueDate = null @@ -206,6 +237,11 @@ for (const rd in response.data.tasks[t].reminderDates) { response.data.tasks[t].reminderDates[rd] = new Date(response.data.tasks[t].reminderDates[rd] * 1000) } + + // Make subtasks into empty array if null + if (response.data.tasks[t].subtasks === null) { + response.data.tasks[t].subtasks = [] + } } // This adds a new elemednt "list" to our object which contains all lists @@ -223,9 +259,9 @@ addTask() { const cancel = message.setLoading(this) - HTTP.put(`lists/` + this.$route.params.id, {text: this.newTask}, {headers: {'Authorization': 'Bearer ' + localStorage.getItem('token')}}) + HTTP.put(`lists/` + this.$route.params.id, this.newTask, {headers: {'Authorization': 'Bearer ' + localStorage.getItem('token')}}) .then(response => { - this.list.tasks.push(response.data) + this.addTaskToList(response.data) this.handleSuccess({message: 'The task was successfully created.'}) cancel() // cancel the timer }) @@ -234,8 +270,27 @@ this.handleError(e) }) - this.newTask = '' + this.newTask = {} }, + addTaskToList(task) { + // If it's a subtask, add it to its parent, otherwise append it to the list of tasks + if (task.parentTaskID === 0) { + this.list.tasks.push(task) + } else { + for (const t in this.list.tasks) { + if (this.list.tasks[t].id === task.parentTaskID) { + this.list.tasks[t].subtasks.push(task) + break + } + } + } + + // Update the current edit task if needed + if (task.ParentTask === this.taskEditTask.id) { + this.taskEditTask.subtasks.push(task) + } + + }, markAsDone(e) { const cancel = message.setLoading(this) @@ -288,6 +343,11 @@ this.repeatAfter.type = 'hours' this.repeatAfter.amount = repeatAfterHours } + + if(this.taskEditTask.subtasks === null) { + this.taskEditTask.subtasks = []; + } + this.isTaskEdit = true }, editTaskSubmit() { @@ -345,13 +405,25 @@ this.handleError(e) }) }, + addSubtask() { + this.newTask.parentTaskID = this.taskEditTask.id + this.addTask() + }, updateTaskByID(id, updatedTask) { for (const t in this.list.tasks) { if (this.list.tasks[t].id === id) { - //updatedTask.reminderDates = this.makeJSReminderDatesAfterUpdate(updatedTask.reminderDates) this.$set(this.list.tasks, t, updatedTask) break } + + if (this.list.tasks[t].id === updatedTask.parentTaskID) { + for (const s in this.list.tasks[t].subtasks) { + if (this.list.tasks[t].subtasks[s].id === updatedTask.id) { + this.$set(this.list.tasks[t].subtasks, s, updatedTask) + break + } + } + } } }, updateLastReminderDate(selectedDates) { diff --git a/src/vikunja.scss b/src/vikunja.scss index 63f1e8a3..3f9de0a7 100644 --- a/src/vikunja.scss +++ b/src/vikunja.scss @@ -84,6 +84,10 @@ h1,h2,h3,h4,h5,h6{ margin-right: 0.5rem; } +.tasks.noborder{ + margin: 1rem -0.5rem; +} + .tasks { margin-top: 1rem; padding: 0; @@ -124,6 +128,16 @@ h1,h2,h3,h4,h5,h6{ min-height: calc(100% - 1rem); margin-top: 1rem; + .subtasks { + input { + width: auto; + } + + .button { + float:right; + } + } + .reminder-input{ margin: 0; diff --git a/todo.md b/todo.md index 33ffdec7..8433e8c8 100644 --- a/todo.md +++ b/todo.md @@ -44,6 +44,7 @@ * [ ] Alles abgehakte ausblenden, mit btn zum wieder einblenden * [x] Den Sharing-Updateshit mit der neuen methode machen (post) * [x] User suchen einbauen, mit neuem endpoint +* [ ] Wenn man den Namen einer Liste updated wird der Name in der List nicht upgedated ## Funktionen aus der API @@ -83,8 +84,7 @@ * [ ] Users with access to a namespace * [ ] Teams with access to a list * [ ] Teams with access to a namespace -* [ ] Subtasks - * [ ] Subtasks genauso verwalten können wie richtige Tasks +* [x] Subtasks * [ ] Priorities * [ ] Sachen mit hoher Prio irgendwie hervorheben (rotes Dreieck zb) * [ ] Listen Kopieren