diff --git a/src/components/home/navigation.vue b/src/components/home/navigation.vue index 65b045088..ed91c1771 100644 --- a/src/components/home/navigation.vue +++ b/src/components/home/navigation.vue @@ -54,14 +54,14 @@ + v-tooltip="getNamespaceTitle(n) + ' (' + n.lists.filter(l => !l.isArchived).length + ')'"> - {{ n.title }} ({{ n.lists.filter(l => !l.isArchived).length }}) + {{ getNamespaceTitle(n) }} ({{ n.lists.filter(l => !l.isArchived).length }}) - {{ l.title }} + {{ getListTitle(l) }} - {{ currentList.title === '' ? $t('misc.loading') : currentList.title }} + {{ currentList.title === '' ? $t('misc.loading') : getListTitle(currentList) }} diff --git a/src/helpers/getListTitle.js b/src/helpers/getListTitle.js new file mode 100644 index 000000000..35c943e32 --- /dev/null +++ b/src/helpers/getListTitle.js @@ -0,0 +1,6 @@ +export const getListTitle = (l, $t) => { + if (l.id === -1) { + return $t('list.pseudo.favorites.title'); + } + return l.title; +} diff --git a/src/helpers/getNamespaceTitle.js b/src/helpers/getNamespaceTitle.js new file mode 100644 index 000000000..21fe7b7e4 --- /dev/null +++ b/src/helpers/getNamespaceTitle.js @@ -0,0 +1,12 @@ +export const getNamespaceTitle = (n, $t) => { + if (n.id === -1) { + return $t('namespace.pseudo.sharedLists.title'); + } + if (n.id === -2) { + return $t('namespace.pseudo.favorites.title'); + } + if (n.id === -3) { + return $t('namespace.pseudo.savedFilters.title'); + } + return n.title; +} diff --git a/src/i18n/lang/en.json b/src/i18n/lang/en.json index 3ee413139..889ed5e9a 100644 --- a/src/i18n/lang/en.json +++ b/src/i18n/lang/en.json @@ -245,6 +245,11 @@ "bucketTitleSavedSuccess": "The bucket title has been saved successfully.", "bucketLimitSavedSuccess": "The bucket limit been saved successfully.", "collapse": "Collapse this bucket" + }, + "pseudo": { + "favorites": { + "title": "Favorites" + } } }, "namespace": { @@ -294,6 +299,17 @@ "color": "Color", "archived": "Is Archived", "isArchived": "This namespace is archived" + }, + "pseudo": { + "sharedLists": { + "title": "Shared Lists" + }, + "favorites": { + "title": "Favorites" + }, + "savedFilters": { + "title": "Filters" + } } }, "filters": { diff --git a/src/main.js b/src/main.js index ce389dcf0..7475e9575 100644 --- a/src/main.js +++ b/src/main.js @@ -85,6 +85,8 @@ import vueShortkey from 'vue-shortkey' import message from './message' import {colorIsDark} from './helpers/color/colorIsDark' import {setTitle} from './helpers/setTitle' +import {getNamespaceTitle} from './helpers/getNamespaceTitle' +import {getListTitle} from './helpers/getListTitle' // Vuex import {store} from './store' // i18n @@ -199,6 +201,12 @@ Vue.mixin({ formatDateShort(date) { return formatDate(date, 'PPpp', this.$t('date.locale')) }, + getNamespaceTitle(n) { + return getNamespaceTitle(n, p => this.$t(p)) + }, + getListTitle(l) { + return getListTitle(l, p => this.$t(p)) + }, error(e, actions = []) { return message.error(e, this, p => this.$t(p), actions) }, diff --git a/src/store/index.js b/src/store/index.js index dbe860673..ef235f649 100644 --- a/src/store/index.js +++ b/src/store/index.js @@ -20,7 +20,6 @@ import attachments from './modules/attachments' import labels from './modules/labels' import ListService from '../services/list' -import {setTitle} from '@/helpers/setTitle' Vue.use(Vuex) @@ -69,8 +68,6 @@ export const store = new Vuex.Store({ return } - setTitle(currentList.title) - // Not sure if this is the right way to do it but hey, it works if ( // List changed @@ -140,4 +137,4 @@ export const store = new Vuex.Store({ state.quickActionsActive = active }, }, -}) \ No newline at end of file +}) diff --git a/src/views/list/ShowList.vue b/src/views/list/ShowList.vue index e2ec94c3d..086e0bcdd 100644 --- a/src/views/list/ShowList.vue +++ b/src/views/list/ShowList.vue @@ -97,7 +97,7 @@ export default { saveListToHistory(listData) - this.setTitle(this.currentList.title) + this.setTitle(this.currentList.id ? this.getListTitle(this.currentList) : '') // This invalidates the loaded list at the kanban board which lets it reload its content when // switched to it. This ensures updates done to tasks in the gantt or list views are consistently @@ -144,6 +144,7 @@ export default { .then(r => { this.$set(this, 'list', r) this.$store.commit(CURRENT_LIST, r) + this.setTitle(this.getListTitle(r)) }) .catch(e => { this.error(e) @@ -154,4 +155,4 @@ export default { }, }, } - \ No newline at end of file + diff --git a/src/views/namespaces/ListNamespaces.vue b/src/views/namespaces/ListNamespaces.vue index d8fe0fd59..1f520816c 100644 --- a/src/views/namespaces/ListNamespaces.vue +++ b/src/views/namespaces/ListNamespaces.vue @@ -39,7 +39,7 @@

- {{ n.title }} + {{ getNamespaceTitle(n) }} {{ $t('namespace.archived') }} diff --git a/src/views/tasks/TaskDetailView.vue b/src/views/tasks/TaskDetailView.vue index 6330e25b6..7092b38e8 100644 --- a/src/views/tasks/TaskDetailView.vue +++ b/src/views/tasks/TaskDetailView.vue @@ -3,9 +3,9 @@
- {{ parent.namespace.title }} > + {{ getNamespaceTitle(parent.namespace) }} > - {{ parent.list.title }} + {{ getListTitle(parent.list) }}