Chamilo is a learning management system focused on ease of use and accessibility
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.
 
 
 
 
 
 
chamilo-lms/assets/vue/components/social/SocialSideMenu.vue

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>