2019-11-24 14:16:24 +01:00
|
|
|
<template>
|
|
|
|
<div class="task-relations">
|
|
|
|
<label class="label">New Task Relation</label>
|
2020-04-26 15:44:23 +02:00
|
|
|
<div class="field">
|
|
|
|
<multiselect
|
|
|
|
v-model="newTaskRelationTask"
|
|
|
|
:options="foundTasks"
|
|
|
|
:multiple="false"
|
|
|
|
:searchable="true"
|
|
|
|
:loading="taskService.loading"
|
|
|
|
:internal-search="true"
|
|
|
|
@search-change="findTasks"
|
|
|
|
placeholder="Type search for a new task to add as related..."
|
|
|
|
label="text"
|
|
|
|
track-by="id"
|
|
|
|
:taggable="true"
|
|
|
|
:showNoOptions="false"
|
|
|
|
@tag="createAndRelateTask"
|
|
|
|
tag-placeholder="Add this as new related task"
|
|
|
|
>
|
|
|
|
<template slot="clear" slot-scope="props">
|
|
|
|
<div
|
|
|
|
class="multiselect__clear"
|
2020-03-04 21:29:40 +01:00
|
|
|
v-if="newTaskRelationTask !== null && newTaskRelationTask.id !== 0"
|
|
|
|
@mousedown.prevent.stop="clearAllFoundTasks(props.search)"></div>
|
2020-04-26 15:44:23 +02:00
|
|
|
</template>
|
|
|
|
<span slot="noResult">No task found. Consider changing the search query.</span>
|
|
|
|
</multiselect>
|
|
|
|
</div>
|
|
|
|
<div class="field has-addons">
|
|
|
|
<div class="control is-expanded">
|
|
|
|
<div class="select is-fullwidth has-defaults">
|
|
|
|
<select v-model="newTaskRelationKind">
|
|
|
|
<option value="unset">Select a relation kind</option>
|
|
|
|
<option v-for="(label, rk) in relationKinds" :key="rk" :value="rk">
|
|
|
|
{{ label[0] }}
|
|
|
|
</option>
|
|
|
|
</select>
|
2019-11-24 14:16:24 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
2020-04-26 15:44:23 +02:00
|
|
|
<div class="control">
|
|
|
|
<a class="button is-primary" @click="addTaskRelation()">Add task Relation</a>
|
|
|
|
</div>
|
2019-11-24 14:16:24 +01:00
|
|
|
</div>
|
|
|
|
|
2019-12-15 21:42:40 +01:00
|
|
|
<div class="related-tasks" v-for="(rts, kind ) in relatedTasks" :key="kind">
|
|
|
|
<template v-if="rts.length > 0">
|
2020-04-14 22:23:42 +02:00
|
|
|
<span class="title">{{ relationKindTitle(kind, rts.length) }}</span>
|
2019-12-15 21:42:40 +01:00
|
|
|
<div class="tasks noborder">
|
|
|
|
<div class="task" v-for="t in rts" :key="t.id">
|
2020-05-09 19:33:37 +02:00
|
|
|
<router-link :to="{ name: $route.name, params: { id: t.id } }">
|
2019-12-15 21:42:40 +01:00
|
|
|
<span class="tasktext" :class="{ 'done': t.done}">
|
2020-05-09 19:33:37 +02:00
|
|
|
<span v-if="t.listId !== listId" class="different-list" v-tooltip="'This task belongs to a different list.'">
|
2020-05-09 23:32:04 +02:00
|
|
|
{{ $store.getters['namespaces/getListById'](t.listId) === null ? '' : $store.getters['namespaces/getListById'](t.listId).title }} >
|
2020-05-09 19:33:37 +02:00
|
|
|
</span>
|
2019-12-15 21:42:40 +01:00
|
|
|
{{t.text}}
|
|
|
|
</span>
|
|
|
|
</router-link>
|
2020-04-26 15:44:23 +02:00
|
|
|
<a
|
|
|
|
class="remove"
|
|
|
|
@click="() => {showDeleteModal = true; relationToDelete = {relationKind: kind, otherTaskId: t.id}}">
|
2019-12-15 21:42:40 +01:00
|
|
|
<icon icon="trash-alt"/>
|
|
|
|
</a>
|
|
|
|
</div>
|
2019-11-24 14:16:24 +01:00
|
|
|
</div>
|
2019-12-15 21:42:40 +01:00
|
|
|
</template>
|
2019-11-24 14:16:24 +01:00
|
|
|
</div>
|
2020-03-04 21:29:40 +01:00
|
|
|
<p v-if="showNoRelationsNotice && Object.keys(relatedTasks).length === 0" class="none">
|
|
|
|
No task relations yet.
|
|
|
|
</p>
|
2019-11-24 14:16:24 +01:00
|
|
|
|
|
|
|
<!-- Delete modal -->
|
|
|
|
<modal
|
|
|
|
v-if="showDeleteModal"
|
|
|
|
@close="showDeleteModal = false"
|
|
|
|
@submit="removeTaskRelation()">
|
|
|
|
<span slot="header">Delete Task Relation</span>
|
|
|
|
<p slot="text">Are you sure you want to delete this task relation?<br/>
|
|
|
|
<b>This CANNOT BE UNDONE!</b></p>
|
|
|
|
</modal>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import TaskService from '../../../services/task'
|
|
|
|
import TaskModel from '../../../models/task'
|
|
|
|
import TaskRelationService from '../../../services/taskRelation'
|
|
|
|
import relationKinds from '../../../models/relationKinds'
|
|
|
|
import TaskRelationModel from '../../../models/taskRelation'
|
|
|
|
|
|
|
|
import multiselect from 'vue-multiselect'
|
|
|
|
|
|
|
|
export default {
|
|
|
|
name: 'relatedTasks',
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
relatedTasks: {},
|
|
|
|
taskService: TaskService,
|
|
|
|
foundTasks: [],
|
|
|
|
relationKinds: relationKinds,
|
|
|
|
newTaskRelationTask: TaskModel,
|
2020-03-04 21:29:40 +01:00
|
|
|
newTaskRelationKind: 'related',
|
2019-11-24 14:16:24 +01:00
|
|
|
taskRelationService: TaskRelationService,
|
|
|
|
showDeleteModal: false,
|
|
|
|
relationToDelete: {},
|
|
|
|
}
|
|
|
|
},
|
|
|
|
components: {
|
|
|
|
multiselect,
|
|
|
|
},
|
|
|
|
props: {
|
2020-04-17 12:19:53 +02:00
|
|
|
taskId: {
|
2019-11-24 14:16:24 +01:00
|
|
|
type: Number,
|
|
|
|
required: true,
|
|
|
|
},
|
|
|
|
initialRelatedTasks: {
|
|
|
|
type: Object,
|
2020-03-04 21:29:40 +01:00
|
|
|
default: () => {
|
|
|
|
},
|
2019-11-24 14:16:24 +01:00
|
|
|
},
|
|
|
|
showNoRelationsNotice: {
|
|
|
|
type: Boolean,
|
|
|
|
default: false,
|
|
|
|
},
|
2020-03-04 21:29:40 +01:00
|
|
|
listId: {
|
|
|
|
type: Number,
|
|
|
|
default: 0,
|
|
|
|
}
|
2019-11-24 14:16:24 +01:00
|
|
|
},
|
|
|
|
created() {
|
|
|
|
this.taskService = new TaskService()
|
|
|
|
this.taskRelationService = new TaskRelationService()
|
|
|
|
this.newTaskRelationTask = new TaskModel()
|
|
|
|
},
|
|
|
|
watch: {
|
|
|
|
initialRelatedTasks(newVal) {
|
|
|
|
this.relatedTasks = newVal
|
|
|
|
},
|
|
|
|
},
|
|
|
|
mounted() {
|
|
|
|
this.relatedTasks = this.initialRelatedTasks
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
findTasks(query) {
|
|
|
|
if (query === '') {
|
|
|
|
this.clearAllFoundTasks()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
this.taskService.getAll({}, {s: query})
|
|
|
|
.then(response => {
|
|
|
|
this.$set(this, 'foundTasks', response)
|
|
|
|
})
|
|
|
|
.catch(e => {
|
2020-01-30 22:47:08 +01:00
|
|
|
this.error(e, this)
|
2019-11-24 14:16:24 +01:00
|
|
|
})
|
|
|
|
},
|
|
|
|
clearAllFoundTasks() {
|
|
|
|
this.$set(this, 'foundTasks', [])
|
|
|
|
},
|
|
|
|
addTaskRelation() {
|
|
|
|
let rel = new TaskRelationModel({
|
2020-04-17 12:19:53 +02:00
|
|
|
taskId: this.taskId,
|
2020-04-12 23:54:46 +02:00
|
|
|
otherTaskId: this.newTaskRelationTask.id,
|
|
|
|
relationKind: this.newTaskRelationKind,
|
2019-11-24 14:16:24 +01:00
|
|
|
})
|
|
|
|
this.taskRelationService.create(rel)
|
|
|
|
.then(() => {
|
|
|
|
if (!this.relatedTasks[this.newTaskRelationKind]) {
|
|
|
|
this.$set(this.relatedTasks, this.newTaskRelationKind, [])
|
|
|
|
}
|
|
|
|
this.relatedTasks[this.newTaskRelationKind].push(this.newTaskRelationTask)
|
|
|
|
this.newTaskRelationKind = 'unset'
|
|
|
|
this.newTaskRelationTask = new TaskModel()
|
2020-01-30 22:47:08 +01:00
|
|
|
this.success({message: 'The task relation was created successfully'}, this)
|
2019-11-24 14:16:24 +01:00
|
|
|
})
|
|
|
|
.catch(e => {
|
2020-01-30 22:47:08 +01:00
|
|
|
this.error(e, this)
|
2019-11-24 14:16:24 +01:00
|
|
|
})
|
|
|
|
},
|
|
|
|
removeTaskRelation() {
|
|
|
|
let rel = new TaskRelationModel({
|
2020-04-12 23:54:46 +02:00
|
|
|
relationKind: this.relationToDelete.relationKind,
|
2020-04-17 12:19:53 +02:00
|
|
|
taskId: this.taskId,
|
2020-04-12 23:54:46 +02:00
|
|
|
otherTaskId: this.relationToDelete.otherTaskId,
|
2019-11-24 14:16:24 +01:00
|
|
|
})
|
|
|
|
this.taskRelationService.delete(rel)
|
|
|
|
.then(r => {
|
2020-03-04 21:29:40 +01:00
|
|
|
Object.keys(this.relatedTasks).forEach(relationKind => {
|
2019-11-24 14:16:24 +01:00
|
|
|
for (const t in this.relatedTasks[relationKind]) {
|
2020-04-12 23:54:46 +02:00
|
|
|
if (this.relatedTasks[relationKind][t].id === this.relationToDelete.otherTaskId && relationKind === this.relationToDelete.relationKind) {
|
2019-11-24 14:16:24 +01:00
|
|
|
this.relatedTasks[relationKind].splice(t, 1)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
2020-01-30 22:47:08 +01:00
|
|
|
this.success(r, this)
|
2019-11-24 14:16:24 +01:00
|
|
|
})
|
|
|
|
.catch(e => {
|
2020-01-30 22:47:08 +01:00
|
|
|
this.error(e, this)
|
2019-11-24 14:16:24 +01:00
|
|
|
})
|
|
|
|
.finally(() => {
|
|
|
|
this.showDeleteModal = false
|
|
|
|
})
|
|
|
|
},
|
2020-03-04 21:29:40 +01:00
|
|
|
createAndRelateTask(text) {
|
2020-04-12 23:54:46 +02:00
|
|
|
const newTask = new TaskModel({text: text, listId: this.listId})
|
2020-03-04 21:29:40 +01:00
|
|
|
this.taskService.create(newTask)
|
|
|
|
.then(r => {
|
|
|
|
this.newTaskRelationTask = r
|
|
|
|
this.addTaskRelation()
|
|
|
|
})
|
|
|
|
.catch(e => {
|
|
|
|
this.error(e, this)
|
|
|
|
})
|
|
|
|
},
|
2020-04-14 22:23:42 +02:00
|
|
|
relationKindTitle(kind, length) {
|
|
|
|
if (length > 1) {
|
|
|
|
return relationKinds[kind][1]
|
|
|
|
}
|
|
|
|
return relationKinds[kind][0]
|
|
|
|
}
|
2019-11-24 14:16:24 +01:00
|
|
|
},
|
|
|
|
}
|
|
|
|
</script>
|