You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
150 lines
5.5 KiB
150 lines
5.5 KiB
<template>
|
|
<BaseCard class="social-side-menu mt-4">
|
|
<template #header>
|
|
<div class="px-4 py-2 -mb-2 bg-gray-15">
|
|
<h2 class="text-h5">{{ t('Social Network') }}</h2>
|
|
</div>
|
|
</template>
|
|
<hr class="-mt-2 mb-4 -mx-4">
|
|
<ul v-if="isCurrentUser" class="menu-list">
|
|
<li :class="['menu-item', { 'active': isActive('/social') }]">
|
|
<router-link to="/social">
|
|
<i class="mdi mdi-home" aria-hidden="true"></i>
|
|
{{ t("Home") }}
|
|
</router-link>
|
|
</li>
|
|
<li :class="['menu-item', { 'active': isActive('/resources/messages') }]">
|
|
<router-link to="/resources/messages">
|
|
<i class="mdi mdi-email" aria-hidden="true"></i>
|
|
{{ t("Messages") }}
|
|
<span class="badge badge-warning">{{ unreadMessagesCount }}</span>
|
|
</router-link>
|
|
</li>
|
|
|
|
<li :class="['menu-item', { 'active': isActive('/resources/personal_files') }]">
|
|
<router-link :to="{ name: 'PersonalFileList', params: { node: currentNodeId } }">
|
|
<i class="mdi mdi-briefcase"></i>
|
|
{{ t("My files") }}
|
|
</router-link>
|
|
</li>
|
|
<li :class="['menu-item', { 'active': isActive('/account/home') }]">
|
|
<router-link :to="{ name: 'AccountHome' }">
|
|
<i class="mdi mdi-account-circle" aria-hidden="true"></i>
|
|
{{ t("My Profile") }}
|
|
</router-link>
|
|
</li>
|
|
<li :class="['menu-item', { 'active': isActive('/resources/friends') }]">
|
|
<router-link :to="{ name: 'UserRelUserList' }">
|
|
<i class="mdi mdi-handshake" aria-hidden="true"></i>
|
|
{{ t("My Friends") }}
|
|
</router-link>
|
|
</li>
|
|
<li :class="['menu-item', { 'active': isActive(groupLink) }]">
|
|
<a v-if="isValidGlobalForumsCourse" :href="groupLink" rel="noopener noreferrer">
|
|
<i class="mdi mdi-group" aria-hidden="true"></i>
|
|
{{ t("Social Groups") }}
|
|
</a>
|
|
<router-link v-else :to="groupLink">
|
|
<i class="mdi mdi-group" aria-hidden="true"></i>
|
|
{{ t("Social Groups") }}
|
|
</router-link>
|
|
</li>
|
|
<li :class="['menu-item', { 'active': isActive('/social', 'promoted') }]">
|
|
<router-link :to="{ path: '/social', query: { filterType: 'promoted' } }">
|
|
<i class="mdi mdi-star" aria-hidden="true"></i>
|
|
{{ t("Promoted Messages") }}
|
|
</router-link>
|
|
</li>
|
|
<li :class="['menu-item', { 'active': isActive('/resources/users/personal_data') }]">
|
|
<router-link to="/resources/users/personal_data">
|
|
<i class="mdi mdi-account" aria-hidden="true"></i>
|
|
{{ t("Personal Data") }}
|
|
</router-link>
|
|
</li>
|
|
</ul>
|
|
<ul v-else class="menu-list">
|
|
<li class="menu-item">
|
|
<router-link to="/social">
|
|
<i class="mdi mdi-home" aria-hidden="true"></i>
|
|
{{ t("Home") }}
|
|
</router-link>
|
|
</li>
|
|
<li class="menu-item">
|
|
<a href="/main/inc/ajax/user_manager.ajax.php?a=get_user_popup&user_id={{user.id}}" class="ajax" rel="noopener noreferrer">
|
|
<i class="mdi mdi-email" aria-hidden="true"></i>
|
|
{{ t("Send message") }}
|
|
</a>
|
|
</li>
|
|
</ul>
|
|
</BaseCard>
|
|
</template>
|
|
|
|
<script setup>
|
|
import BaseCard from "../basecomponents/BaseCard.vue"
|
|
import { useRoute } from 'vue-router'
|
|
import { useI18n } from "vue-i18n"
|
|
import { useMessageRelUserStore } from "../../store/messageRelUserStore"
|
|
import { onMounted, computed, ref, inject, watchEffect } from "vue"
|
|
import { useStore } from "vuex"
|
|
import { useSecurityStore } from "../../store/securityStore"
|
|
import axios from "axios"
|
|
import { usePlatformConfig } from "../../store/platformConfig"
|
|
|
|
const { t } = useI18n()
|
|
const route = useRoute()
|
|
const store = useStore()
|
|
const securityStore = useSecurityStore()
|
|
const currentNodeId = ref(0)
|
|
const messageRelUserStore = useMessageRelUserStore()
|
|
const unreadMessagesCount = computed(() => messageRelUserStore.countUnread)
|
|
|
|
const user = inject('social-user')
|
|
const isCurrentUser = inject('is-current-user')
|
|
const groupLink = ref({ name: 'UserGroupShow' })
|
|
const platformConfigStore = usePlatformConfig()
|
|
const globalForumsCourse = computed(() => platformConfigStore.getSetting("forum.global_forums_course_id"))
|
|
const isValidGlobalForumsCourse = computed(() => {
|
|
const courseId = globalForumsCourse.value
|
|
return courseId !== null && courseId !== undefined && courseId > 0
|
|
})
|
|
const getGroupLink = async () => {
|
|
try {
|
|
const response = await axios.get('/social-network/get-forum-link')
|
|
if (isValidGlobalForumsCourse.value) {
|
|
groupLink.value = response.data.go_to
|
|
} else {
|
|
groupLink.value = { name: 'UserGroupShow' }
|
|
}
|
|
} catch (error) {
|
|
console.error('Error fetching forum link:', error)
|
|
groupLink.value = { name: 'UserGroupShow' }
|
|
}
|
|
}
|
|
|
|
const isActive = (path, filterType = null) => {
|
|
const pathMatch = route.path.startsWith(path)
|
|
const hasQueryParams = Object.keys(route.query).length > 0
|
|
const filterMatch = filterType ? (route.query.filterType === filterType && hasQueryParams) : !hasQueryParams
|
|
return pathMatch && filterMatch
|
|
}
|
|
|
|
watchEffect(() => {
|
|
try {
|
|
if (user.value && user.value.resourceNode) {
|
|
currentNodeId.value = user.value.resourceNode.id
|
|
} else {
|
|
let currentUser = securityStore.user
|
|
if (currentUser && currentUser.resourceNode) {
|
|
currentNodeId.value = currentUser.resourceNode.id
|
|
}
|
|
}
|
|
messageRelUserStore.findUnreadCount()
|
|
} catch (e) {
|
|
console.error('Error loading user:', e)
|
|
}
|
|
})
|
|
|
|
onMounted(async () => {
|
|
await getGroupLink()
|
|
})
|
|
</script>
|
|
|