Add list title in overview page

This commit is contained in:
kolaente 2020-05-11 16:52:58 +02:00
parent b85f66140b
commit 995dec33ea
No known key found for this signature in database
GPG key ID: F40E70337AB24C9B
7 changed files with 62 additions and 14 deletions

View file

@ -9,7 +9,7 @@
<div class="spinner" :class="{ 'is-loading': taskService.loading}"></div> <div class="spinner" :class="{ 'is-loading': taskService.loading}"></div>
<div class="tasks" v-if="tasks && tasks.length > 0"> <div class="tasks" v-if="tasks && tasks.length > 0">
<div class="task" v-for="t in tasks" :key="t.id"> <div class="task" v-for="t in tasks" :key="t.id">
<single-task-in-list :the-task="t" @taskUpdated="updateTasks"/> <single-task-in-list :the-task="t" @taskUpdated="updateTasks" :show-list="true"/>
</div> </div>
</div> </div>
</div> </div>

View file

@ -51,7 +51,7 @@
<router-link :to="{ name: $route.name, params: { id: t.id } }"> <router-link :to="{ name: $route.name, params: { id: t.id } }">
<span class="tasktext" :class="{ 'done': t.done}"> <span class="tasktext" :class="{ 'done': t.done}">
<span v-if="t.listId !== listId" class="different-list" v-tooltip="'This task belongs to a different list.'"> <span v-if="t.listId !== listId" class="different-list" v-tooltip="'This task belongs to a different list.'">
{{ $store.getters['namespaces/getListById'](t.listId) === null ? '' : $store.getters['namespaces/getListById'](t.listId).title }} > {{ $store.getters['lists/getListById'](t.listId) === null ? '' : $store.getters['lists/getListById'](t.listId).title }} >
</span> </span>
{{t.text}} {{t.text}}
</span> </span>

View file

@ -2,6 +2,15 @@
<span> <span>
<fancycheckbox v-model="task.done" @change="markAsDone" :disabled="isArchived"/> <fancycheckbox v-model="task.done" @change="markAsDone" :disabled="isArchived"/>
<router-link :to="{ name: taskDetailRoute, params: { id: task.id } }" class="tasktext" :class="{ 'done': task.done}"> <router-link :to="{ name: taskDetailRoute, params: { id: task.id } }" class="tasktext" :class="{ 'done': task.done}">
<router-link
v-if="showList && $store.getters['lists/getListById'](task.listId) !== null"
v-tooltip="`This task belongs to list '${$store.getters['lists/getListById'](task.listId).title}'`"
:to="{ name: 'list.list', params: { listId: task.listId } }"
class="task-list">
{{ $store.getters['lists/getListById'](task.listId).title }}
</router-link>
<!-- Show any parent tasks to make it clear this task is a sub task of something --> <!-- Show any parent tasks to make it clear this task is a sub task of something -->
<span class="parent-tasks" v-if="typeof task.relatedTasks.parenttask !== 'undefined'"> <span class="parent-tasks" v-if="typeof task.relatedTasks.parenttask !== 'undefined'">
<template v-for="(pt, i) in task.relatedTasks.parenttask"> <template v-for="(pt, i) in task.relatedTasks.parenttask">
@ -61,7 +70,11 @@
taskDetailRoute: { taskDetailRoute: {
type: String, type: String,
default: 'task.list.detail' default: 'task.list.detail'
} },
showList: {
type: Boolean,
default: false,
},
}, },
watch: { watch: {
theTask(newVal) { theTask(newVal) {

View file

@ -2,12 +2,13 @@ import Vue from 'vue'
import Vuex from 'vuex' import Vuex from 'vuex'
Vue.use(Vuex) Vue.use(Vuex)
import {CURRENT_LIST, ERROR_MESSAGE, IS_FULLPAGE, LOADING, ONLINE} from './mutation-types'
import config from './modules/config' import config from './modules/config'
import auth from './modules/auth' import auth from './modules/auth'
import namespaces from './modules/namespaces' import namespaces from './modules/namespaces'
import kanban from './modules/kanban' import kanban from './modules/kanban'
import tasks from './modules/tasks' import tasks from './modules/tasks'
import {CURRENT_LIST, ERROR_MESSAGE, IS_FULLPAGE, LOADING, ONLINE} from './mutation-types' import lists from './modules/lists'
export const store = new Vuex.Store({ export const store = new Vuex.Store({
modules: { modules: {
@ -16,6 +17,7 @@ export const store = new Vuex.Store({
namespaces, namespaces,
kanban, kanban,
tasks, tasks,
lists,
}, },
state: { state: {
loading: false, loading: false,

View file

@ -0,0 +1,25 @@
import Vue from 'vue'
export default {
namespaced: true,
// The state is an object which has the list ids as keys.
state: () => ({}),
mutations: {
addList(state, list) {
Vue.set(state, list.id, list)
},
addLists(state, lists) {
lists.forEach(l => {
Vue.set(state, l.id, l)
})
},
},
getters: {
getListById: state => id => {
if(typeof state[id] !== 'undefined') {
return state[id]
}
return null
},
},
}

View file

@ -47,16 +47,6 @@ export default {
}, },
}, },
getters: { getters: {
getListById: state => id => {
for (const n in state.namespaces) {
for (const l in state.namespaces[n].lists) {
if (state.namespaces[n].lists[l].id === id) {
return state.namespaces[n].lists[l]
}
}
}
return null
},
getListAndNamespaceById: state => listId => { getListAndNamespaceById: state => listId => {
for (const n in state.namespaces) { for (const n in state.namespaces) {
for (const l in state.namespaces[n].lists) { for (const l in state.namespaces[n].lists) {
@ -78,6 +68,17 @@ export default {
return namespaceService.getAll({}, {is_archived: true}) return namespaceService.getAll({}, {is_archived: true})
.then(r => { .then(r => {
ctx.commit('namespaces', r) ctx.commit('namespaces', r)
// Put all lists in the list state
const lists = []
r.forEach(n => {
n.lists.forEach(l => {
lists.push(l)
})
})
ctx.commit('lists/addLists', lists, {root:true})
return Promise.resolve() return Promise.resolve()
}) })
.catch(e => { .catch(e => {

View file

@ -54,6 +54,13 @@
.overdue{ .overdue{
color: $red; color: $red;
} }
.task-list {
width: auto;
color: lighten($grey, 25%);
font-size: .9em;
vertical-align: text-bottom;
}
} }
.tag { .tag {