Subtasks (#9)

This commit is contained in:
konrad 2018-12-19 14:38:21 +00:00 committed by Gitea
parent a8fbf509a1
commit 45579ee237
3 changed files with 97 additions and 11 deletions

View file

@ -9,7 +9,7 @@
<form @submit.prevent="addTask()"> <form @submit.prevent="addTask()">
<div class="field is-grouped"> <div class="field is-grouped">
<p class="control has-icons-left is-expanded" v-bind:class="{ 'is-loading': loading}"> <p class="control has-icons-left is-expanded" v-bind:class="{ 'is-loading': loading}">
<input class="input" v-bind:class="{ 'disabled': loading}" v-model="newTask" type="text" placeholder="Add a new task..."> <input class="input" v-bind:class="{ 'disabled': loading}" v-model="newTask.text" type="text" placeholder="Add a new task...">
<span class="icon is-small is-left"> <span class="icon is-small is-left">
<icon icon="tasks"/> <icon icon="tasks"/>
</span> </span>
@ -127,6 +127,35 @@
</div> </div>
</div> </div>
<div class="field">
<label class="label" for="subtasks">Subtasks</label>
<div class="control subtasks">
<div class="tasks noborder" v-if="taskEditTask.subtasks && taskEditTask.subtasks.length > 0">
<div class="task" v-for="s in taskEditTask.subtasks" v-bind:key="s.id">
<label v-bind:for="s.id">
<div class="fancycheckbox">
<input @change="markAsDone" type="checkbox" v-bind:id="s.id" v-bind:checked="s.done" style="display: none;">
<label v-bind:for="s.id" class="check">
<svg width="18px" height="18px" viewBox="0 0 18 18">
<path d="M1,9 L1,3.5 C1,2 2,1 3.5,1 L14.5,1 C16,1 17,2 17,3.5 L17,14.5 C17,16 16,17 14.5,17 L3.5,17 C2,17 1,16 1,14.5 L1,9 Z"></path>
<polyline points="1 9 7 14 15 4"></polyline>
</svg>
</label>
</div>
<span class="tasktext">
{{s.text}}
</span>
</label>
</div>
</div>
<input :class="{ 'disabled': loading}" :disabled="loading" class="input" type="text" id="tasktext" placeholder="New subtask" v-model="newTask.text"/>
<a class="button" @click="addSubtask()"><icon icon="plus"></icon></a>
</div>
</div>
<button type="submit" class="button is-success is-fullwidth" :class="{ 'is-loading': loading}"> <button type="submit" class="button is-success is-fullwidth" :class="{ 'is-loading': loading}">
Save Save
</button> </button>
@ -153,11 +182,13 @@
return { return {
listID: this.$route.params.id, listID: this.$route.params.id,
list: {}, list: {},
newTask: '', newTask: {text: ''},
error: '', error: '',
loading: false, loading: false,
isTaskEdit: false, isTaskEdit: false,
taskEditTask: {}, taskEditTask: {
subtasks: [],
},
lastReminder: 0, lastReminder: 0,
nowUnix: new Date(), nowUnix: new Date(),
repeatAfter: {type: 'days', amount: null}, repeatAfter: {type: 'days', amount: null},
@ -194,8 +225,8 @@
HTTP.get(`lists/` + this.$route.params.id, {headers: {'Authorization': 'Bearer ' + localStorage.getItem('token')}}) HTTP.get(`lists/` + this.$route.params.id, {headers: {'Authorization': 'Bearer ' + localStorage.getItem('token')}})
.then(response => { .then(response => {
// Make date objects from timestamps
for (const t in response.data.tasks) { for (const t in response.data.tasks) {
// Make date objects from timestamps
let dueDate = new Date(response.data.tasks[t].dueDate * 1000) let dueDate = new Date(response.data.tasks[t].dueDate * 1000)
if (dueDate === 0) { if (dueDate === 0) {
response.data.tasks[t].dueDate = null response.data.tasks[t].dueDate = null
@ -206,6 +237,11 @@
for (const rd in response.data.tasks[t].reminderDates) { for (const rd in response.data.tasks[t].reminderDates) {
response.data.tasks[t].reminderDates[rd] = new Date(response.data.tasks[t].reminderDates[rd] * 1000) 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 // This adds a new elemednt "list" to our object which contains all lists
@ -223,9 +259,9 @@
addTask() { addTask() {
const cancel = message.setLoading(this) 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 => { .then(response => {
this.list.tasks.push(response.data) this.addTaskToList(response.data)
this.handleSuccess({message: 'The task was successfully created.'}) this.handleSuccess({message: 'The task was successfully created.'})
cancel() // cancel the timer cancel() // cancel the timer
}) })
@ -234,7 +270,26 @@
this.handleError(e) 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) { markAsDone(e) {
const cancel = message.setLoading(this) const cancel = message.setLoading(this)
@ -288,6 +343,11 @@
this.repeatAfter.type = 'hours' this.repeatAfter.type = 'hours'
this.repeatAfter.amount = repeatAfterHours this.repeatAfter.amount = repeatAfterHours
} }
if(this.taskEditTask.subtasks === null) {
this.taskEditTask.subtasks = [];
}
this.isTaskEdit = true this.isTaskEdit = true
}, },
editTaskSubmit() { editTaskSubmit() {
@ -345,13 +405,25 @@
this.handleError(e) this.handleError(e)
}) })
}, },
addSubtask() {
this.newTask.parentTaskID = this.taskEditTask.id
this.addTask()
},
updateTaskByID(id, updatedTask) { updateTaskByID(id, updatedTask) {
for (const t in this.list.tasks) { for (const t in this.list.tasks) {
if (this.list.tasks[t].id === id) { if (this.list.tasks[t].id === id) {
//updatedTask.reminderDates = this.makeJSReminderDatesAfterUpdate(updatedTask.reminderDates)
this.$set(this.list.tasks, t, updatedTask) this.$set(this.list.tasks, t, updatedTask)
break 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) { updateLastReminderDate(selectedDates) {

View file

@ -84,6 +84,10 @@ h1,h2,h3,h4,h5,h6{
margin-right: 0.5rem; margin-right: 0.5rem;
} }
.tasks.noborder{
margin: 1rem -0.5rem;
}
.tasks { .tasks {
margin-top: 1rem; margin-top: 1rem;
padding: 0; padding: 0;
@ -124,6 +128,16 @@ h1,h2,h3,h4,h5,h6{
min-height: calc(100% - 1rem); min-height: calc(100% - 1rem);
margin-top: 1rem; margin-top: 1rem;
.subtasks {
input {
width: auto;
}
.button {
float:right;
}
}
.reminder-input{ .reminder-input{
margin: 0; margin: 0;

View file

@ -44,6 +44,7 @@
* [ ] Alles abgehakte ausblenden, mit btn zum wieder einblenden * [ ] Alles abgehakte ausblenden, mit btn zum wieder einblenden
* [x] Den Sharing-Updateshit mit der neuen methode machen (post) * [x] Den Sharing-Updateshit mit der neuen methode machen (post)
* [x] User suchen einbauen, mit neuem endpoint * [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 ## Funktionen aus der API
@ -83,8 +84,7 @@
* [ ] Users with access to a namespace * [ ] Users with access to a namespace
* [ ] Teams with access to a list * [ ] Teams with access to a list
* [ ] Teams with access to a namespace * [ ] Teams with access to a namespace
* [ ] Subtasks * [x] Subtasks
* [ ] Subtasks genauso verwalten können wie richtige Tasks
* [ ] Priorities * [ ] Priorities
* [ ] Sachen mit hoher Prio irgendwie hervorheben (rotes Dreieck zb) * [ ] Sachen mit hoher Prio irgendwie hervorheben (rotes Dreieck zb)
* [ ] Listen Kopieren * [ ] Listen Kopieren