refactor(client): Use getters to avoid watch vuex
This commit is contained in:
@@ -1,6 +1,8 @@
|
||||
import Vuex from 'vuex';
|
||||
import createPersistedState from 'vuex-persistedstate';
|
||||
import * as nestedProperty from 'nested-property';
|
||||
import { faTerminal, faHashtag, faBroadcastTower, faFireAlt, faSearch, faStar, faAt, faListUl, faUserClock, faUsers, faCloud, faGamepad, faFileAlt, faSatellite, faDoorClosed } from '@fortawesome/free-solid-svg-icons';
|
||||
import { faBell, faEnvelope, faComments } from '@fortawesome/free-regular-svg-icons';
|
||||
import { apiUrl } from './config';
|
||||
|
||||
export const defaultSettings = {
|
||||
@@ -81,6 +83,111 @@ export default () => new Vuex.Store({
|
||||
|
||||
getters: {
|
||||
isSignedIn: state => state.i != null,
|
||||
|
||||
nav: (state, getters) => actions => ({
|
||||
notifications: {
|
||||
title: 'notifications',
|
||||
icon: faBell,
|
||||
get show() { return getters.isSignedIn; },
|
||||
get indicated() { return getters.isSignedIn && state.i.hasUnreadNotification; },
|
||||
to: '/my/notifications',
|
||||
},
|
||||
messaging: {
|
||||
title: 'messaging',
|
||||
icon: faComments,
|
||||
get show() { return getters.isSignedIn; },
|
||||
get indicated() { return getters.isSignedIn && state.i.hasUnreadMessagingMessage; },
|
||||
to: '/my/messaging',
|
||||
},
|
||||
drive: {
|
||||
title: 'drive',
|
||||
icon: faCloud,
|
||||
get show() { return getters.isSignedIn; },
|
||||
to: '/my/drive',
|
||||
},
|
||||
followRequests: {
|
||||
title: 'followRequests',
|
||||
icon: faUserClock,
|
||||
get show() { return getters.isSignedIn && state.i.isLocked; },
|
||||
get indicated() { return getters.isSignedIn && state.i.hasPendingReceivedFollowRequest; },
|
||||
to: '/my/follow-requests',
|
||||
},
|
||||
featured: {
|
||||
title: 'featured',
|
||||
icon: faFireAlt,
|
||||
to: '/featured',
|
||||
},
|
||||
explore: {
|
||||
title: 'explore',
|
||||
icon: faHashtag,
|
||||
to: '/explore',
|
||||
},
|
||||
announcements: {
|
||||
title: 'announcements',
|
||||
icon: faBroadcastTower,
|
||||
get indicated() { return getters.isSignedIn && state.i.hasUnreadAnnouncement; },
|
||||
to: '/announcements',
|
||||
},
|
||||
search: {
|
||||
title: 'search',
|
||||
icon: faSearch,
|
||||
action: () => actions.search(),
|
||||
},
|
||||
lists: {
|
||||
title: 'lists',
|
||||
icon: faListUl,
|
||||
get show() { return getters.isSignedIn; },
|
||||
to: '/my/lists',
|
||||
},
|
||||
groups: {
|
||||
title: 'groups',
|
||||
icon: faUsers,
|
||||
get show() { return getters.isSignedIn; },
|
||||
to: '/my/groups',
|
||||
},
|
||||
antennas: {
|
||||
title: 'antennas',
|
||||
icon: faSatellite,
|
||||
get show() { return getters.isSignedIn; },
|
||||
to: '/my/antennas',
|
||||
},
|
||||
mentions: {
|
||||
title: 'mentions',
|
||||
icon: faAt,
|
||||
get show() { return getters.isSignedIn; },
|
||||
get indicated() { return getters.isSignedIn && state.i.hasUnreadMentions; },
|
||||
to: '/my/mentions',
|
||||
},
|
||||
messages: {
|
||||
title: 'directNotes',
|
||||
icon: faEnvelope,
|
||||
get show() { return getters.isSignedIn; },
|
||||
get indicated() { return getters.isSignedIn && state.i.hasUnreadSpecifiedNotes; },
|
||||
to: '/my/messages',
|
||||
},
|
||||
favorites: {
|
||||
title: 'favorites',
|
||||
icon: faStar,
|
||||
get show() { return getters.isSignedIn; },
|
||||
to: '/my/favorites',
|
||||
},
|
||||
pages: {
|
||||
title: 'pages',
|
||||
icon: faFileAlt,
|
||||
get show() { return getters.isSignedIn; },
|
||||
to: '/my/pages',
|
||||
},
|
||||
games: {
|
||||
title: 'games',
|
||||
icon: faGamepad,
|
||||
to: '/games',
|
||||
},
|
||||
scratchpad: {
|
||||
title: 'scratchpad',
|
||||
icon: faTerminal,
|
||||
to: '/scratchpad',
|
||||
},
|
||||
}),
|
||||
},
|
||||
|
||||
mutations: {
|
||||
|
Reference in New Issue
Block a user