2022-08-11 20:56:30 +02:00
|
|
|
import { mapState } from 'vuex'
|
2023-03-17 20:24:22 +01:00
|
|
|
import { TIMELINES, ROOT_ITEMS, routeTo } from 'src/components/navigation/navigation.js'
|
2022-08-15 19:34:45 +02:00
|
|
|
import { getListEntries, filterNavigation } from 'src/components/navigation/filter.js'
|
2022-08-11 20:56:30 +02:00
|
|
|
|
|
|
|
import { library } from '@fortawesome/fontawesome-svg-core'
|
|
|
|
import {
|
|
|
|
faUsers,
|
|
|
|
faGlobe,
|
|
|
|
faBookmark,
|
|
|
|
faEnvelope,
|
|
|
|
faComments,
|
|
|
|
faBell,
|
|
|
|
faInfoCircle,
|
|
|
|
faStream,
|
|
|
|
faList
|
|
|
|
} from '@fortawesome/free-solid-svg-icons'
|
|
|
|
|
|
|
|
library.add(
|
|
|
|
faUsers,
|
|
|
|
faGlobe,
|
|
|
|
faBookmark,
|
|
|
|
faEnvelope,
|
|
|
|
faComments,
|
|
|
|
faBell,
|
|
|
|
faInfoCircle,
|
|
|
|
faStream,
|
|
|
|
faList
|
|
|
|
)
|
2022-08-23 14:36:54 +02:00
|
|
|
|
2022-08-11 20:56:30 +02:00
|
|
|
const NavPanel = {
|
2022-08-12 00:26:19 +02:00
|
|
|
props: ['limit'],
|
2022-08-23 14:36:54 +02:00
|
|
|
methods: {
|
|
|
|
getRouteTo (item) {
|
2023-03-17 20:24:22 +01:00
|
|
|
return routeTo(item, this.currentUser)
|
2022-08-23 14:36:54 +02:00
|
|
|
}
|
|
|
|
},
|
2022-08-11 20:56:30 +02:00
|
|
|
computed: {
|
|
|
|
getters () {
|
|
|
|
return this.$store.getters
|
|
|
|
},
|
|
|
|
...mapState({
|
|
|
|
lists: getListEntries,
|
|
|
|
currentUser: state => state.users.currentUser,
|
|
|
|
followRequestCount: state => state.api.followRequests.length,
|
|
|
|
privateMode: state => state.instance.private,
|
|
|
|
federating: state => state.instance.federating,
|
|
|
|
pleromaChatMessagesAvailable: state => state.instance.pleromaChatMessagesAvailable,
|
2023-04-07 00:14:49 +02:00
|
|
|
supportsAnnouncements: state => state.announcements.supportsAnnouncements,
|
2022-08-11 20:56:30 +02:00
|
|
|
pinnedItems: state => new Set(state.serverSideStorage.prefsStorage.collections.pinnedNavItems)
|
|
|
|
}),
|
|
|
|
pinnedList () {
|
2022-08-11 23:50:08 +02:00
|
|
|
if (!this.currentUser) {
|
2022-12-14 23:53:32 +01:00
|
|
|
return filterNavigation([
|
2022-08-11 23:50:08 +02:00
|
|
|
{ ...TIMELINES.public, name: 'public' },
|
|
|
|
{ ...TIMELINES.twkn, name: 'twkn' },
|
|
|
|
{ ...ROOT_ITEMS.about, name: 'about' }
|
2022-12-14 23:53:32 +01:00
|
|
|
],
|
|
|
|
{
|
|
|
|
hasChats: this.pleromaChatMessagesAvailable,
|
2023-04-07 00:14:49 +02:00
|
|
|
hasAnnouncements: this.supportsAnnouncements,
|
2022-12-14 23:53:32 +01:00
|
|
|
isFederating: this.federating,
|
|
|
|
isPrivate: this.privateMode,
|
|
|
|
currentUser: this.currentUser
|
|
|
|
})
|
2022-08-11 23:50:08 +02:00
|
|
|
}
|
2022-08-11 20:56:30 +02:00
|
|
|
return filterNavigation(
|
|
|
|
[
|
|
|
|
...Object
|
|
|
|
.entries({ ...TIMELINES })
|
|
|
|
.filter(([k]) => this.pinnedItems.has(k))
|
|
|
|
.map(([k, v]) => ({ ...v, name: k })),
|
|
|
|
...this.lists.filter((k) => this.pinnedItems.has(k.name)),
|
|
|
|
...Object
|
|
|
|
.entries({ ...ROOT_ITEMS })
|
|
|
|
.filter(([k]) => this.pinnedItems.has(k))
|
|
|
|
.map(([k, v]) => ({ ...v, name: k }))
|
|
|
|
],
|
|
|
|
{
|
|
|
|
hasChats: this.pleromaChatMessagesAvailable,
|
2023-04-07 00:14:49 +02:00
|
|
|
hasAnnouncements: this.supportsAnnouncements,
|
2022-08-11 20:56:30 +02:00
|
|
|
isFederating: this.federating,
|
2022-08-12 00:19:19 +02:00
|
|
|
isPrivate: this.privateMode,
|
2022-08-11 20:56:30 +02:00
|
|
|
currentUser: this.currentUser
|
|
|
|
}
|
2022-08-12 00:26:19 +02:00
|
|
|
).slice(0, this.limit)
|
2022-08-11 20:56:30 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default NavPanel
|