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/MyFriendsCard.vue

153 lines
4.5 KiB

<template>
<BaseCard
class="my-groups-card bg-white mb-3"
plain
>
<template #header>
<div class="px-4 py-3 bg-gray-200">
<h2 class="text-xl font-semibold">{{ t("My friends") }}</h2>
</div>
</template>
<hr class="my-2" />
<div class="px-4">
<div
v-if="isCurrentUser"
class="flex items-center mb-4"
>
<input
v-model="searchQuery"
:placeholder="t('Search')"
class="flex-grow p-2 h-[44px] border border-gray-300 rounded-l-md focus:outline-none focus:ring-2 focus:ring-blue-500"
type="search"
@input="fetchFriends"
/>
<button
class="p-2 h-[44px] bg-gray-200 border border-gray-300 rounded-r-md hover:bg-gray-300 focus:outline-none focus:ring-2 focus:ring-blue-500"
type="button"
@click="search"
>
<i class="mdi mdi-magnify text-gray-700"></i>
</button>
</div>
<ul class="list-group mb-4">
<li
v-for="friend in limitedFriends"
:key="friend.id"
class="list-group-item friend-item d-flex align-items-center mb-2"
>
<a
:href="`/social?id=${friend.friend.id}`"
class="d-flex align-items-center text-decoration-none"
>
<BaseUserAvatar
:alt="t('Picture')"
:image-url="friend.friend.illustrationUrl"
class="mr-2"
/>
<span
>{{ friend.friend.firstname }} {{ friend.friend.lastname }}
<small class="text-muted">({{ friend.friend.username }})</small></span
>
<span
v-if="friend.friend.isOnline"
class="mdi mdi-circle circle-green mx-2"
title="Online"
></span>
<span
v-else
class="mdi mdi-circle circle-gray mx-2"
title="Offline"
></span>
</a>
</li>
</ul>
<div
v-if="friends.length > 10"
class="mt-2 text-center"
>
<a
href="#"
@click="viewAll"
>{{ t("View all friends") }}</a
>
</div>
</div>
<div
v-if="allowSocialMap && isCurrentUser"
class="text-center mt-3"
>
<BaseButton
:label="t('Search user by geolocalization')"
icon="map-search"
type="primary"
@click="redirectToGeolocalization"
/>
</div>
</BaseCard>
</template>
<script setup>
import BaseCard from "../basecomponents/BaseCard.vue"
import { useI18n } from "vue-i18n"
import { computed, inject, ref, watchEffect } from "vue"
import axios from "axios"
import BaseUserAvatar from "../basecomponents/BaseUserAvatar.vue"
import { ENTRYPOINT } from "../../config/entrypoint"
import { useRouter } from "vue-router"
import { usePlatformConfig } from "../../store/platformConfig"
import BaseButton from "../basecomponents/BaseButton.vue"
const { t } = useI18n()
const friends = ref([])
const searchQuery = ref("")
const user = inject("social-user")
const isCurrentUser = inject("is-current-user")
const router = useRouter()
const platformConfigStore = usePlatformConfig()
const allowSocialMap = computed(() => platformConfigStore.getSetting("profile.allow_social_map_fields"))
const search = () => {
router.push({ name: "SocialSearch", query: { query: searchQuery.value, type: "user" } })
}
const limitedFriends = computed(() => {
return friends.value.slice(0, 10)
})
const redirectToGeolocalization = () => {
window.location.href = "/main/social/map.php"
}
async function fetchFriends(userId) {
try {
const response = await axios.get(`${ENTRYPOINT}user_rel_users?user=/api/users/${userId}&relationType=3`, {
params: {
"friend.username": searchQuery.value ? searchQuery.value : undefined,
},
})
friends.value = response.data["hydra:member"]
const friendIds = friends.value.map((friend) => friend.friend.id)
const onlineStatusResponse = await axios.post(`/social-network/online-status`, { userIds: friendIds })
const onlineStatuses = onlineStatusResponse.data
friends.value.forEach((friend) => {
friend.friend.isOnline = onlineStatuses[friend.friend.id] || false
})
} catch (error) {
console.error("Error fetching friends:", error)
}
}
const viewAll = () => {
if (isCurrentUser) {
router.push("/resources/friends")
} else {
router.push("/resources/friends?id=" + user.value.id)
}
}
watchEffect(() => {
if (user.value && user.value.id) {
fetchFriends(user.value.id)
}
})
</script>