Your IP : 216.73.217.77


Current Path : /home/users/unlimited/www/learnoid.codeskitter.site/resources/js/components/
Upload File :
Current File : /home/users/unlimited/www/learnoid.codeskitter.site/resources/js/components/DashboardHeader.vue

<template>
    <header class="navbar navbar-expand-xl shadow-sm" :class="[{ 'bg-light-primary': $route.path === '/' }]">
        <section class="container">
            <router-link to="/" class="navbar-brand">
                <img :src="masterStore?.masterData?.logo" width="150px" height="50px" class="object-fit-contain"
                    alt="LMS" />
            </router-link>
            <div class="d-flex align-items-center gap-2">
                <div v-if="authStore.authToken" class="dropdown d-lg-none">
                    <a href="#" class="text-decoration-none text-dark" data-bs-toggle="dropdown" aria-expanded="false">
                        <img :src="authStore.userData.profile_picture"
                            class="auth-profile-pic rounded-circle object-fit-cover" alt="Menu" height="45px"
                            width="45px" />
                    </a>
                    <ul class="dropdown-menu position-absolute top-100 start-50 mt-5 translate-middle">
                        <router-link to="/" class="dropdown-item text-primary">
                            <i class="bi bi-house-door me-2"></i>{{ $t('Home') }}
                        </router-link>
                        <li>
                            <a class="dropdown-item" href="#" @click="logout()">{{ $t('Log Out') }}</a>
                        </li>
                    </ul>
                </div>
                <button class="navbar-toggler" type="button" data-bs-toggle="collapse"
                    data-bs-target="#navbarSupportedContent" aria-controls="navbarSupportedContent"
                    aria-expanded="false" aria-label="Toggle navigation" @click="toggleMenu = !toggleMenu">
                    <img v-if="!toggleMenu" src="/public/assets/website/icon/menubar.svg" alt="menubar" />
                    <img v-else src="/public/assets/website/icon/close.svg" alt="menubar" />
                </button>
            </div>
            <div class="collapse navbar-collapse" id="navbarSupportedContent">
                <ul class="navbar-nav me-md-4 ms-auto my-3 my-md-0 mb-lg-0">
                    <li class="nav-item">
                        <router-link to="/" :class="[
                            'nav-link m-0 pb-1 pt-0',
                            $route.path === '/' ? 'active' : '',
                        ]">{{ $t('Home') }}</router-link>
                    </li>
                    <li class="nav-item">
                        <router-link to="/courses" :class="[
                            'nav-link m-0 pb-1 pt-0',
                            $route.path === '/courses' ? 'active' : '',
                        ]">{{ $t('Courses') }}</router-link>
                    </li>
                    <li class="nav-item">
                        <router-link to="/about-us" :class="[
                            'nav-link m-0 pb-1 pt-0',
                            $route.path === '/about-us' ? 'active' : '',
                        ]">{{ $t('About Us') }}</router-link>
                    </li>
                    <li class="nav-item">
                        <router-link to="/contact-us" :class="[
                            'nav-link m-0 pb-1 pt-0',
                            $route.path === '/contact-us' ? 'active' : '',
                        ]">{{ $t('Contact Us') }}</router-link>
                    </li>
                </ul>
                <div v-if="authStore.authToken"
                    class="auth-profile dropdown me-3 my-0 my-lg-2 d-flex justify-content-center align-items-center">
                    <a href="#" class="text-decoration-none text-dark" data-bs-toggle="dropdown" aria-expanded="false">
                        <img :src="authStore.userData.profile_picture"
                            class="auth-profile-pic rounded-circle object-fit-cover" alt="Menu" height="45px"
                            width="45px" />
                    </a>
                    <ul class="dropdown-menu dropdown-menu-end">
                        <router-link to="/" class="dropdown-item text-primary">
                            <i class="bi bi-house-door me-2"></i>{{ $t('Home') }}
                        </router-link>
                        <li>
                            <a class="dropdown-item text-danger" href="#" @click="logout()"><i
                                    class="bi bi-box-arrow-right me-2"></i>{{ $t('Log Out') }}</a>
                        </li>
                    </ul>
                </div>
                <div v-else class="mx-3">
                    <router-link to="/login" class="btn btn-primary rounded-pill w-100 w-md-0">{{ $t('Login') }}</router-link>
                </div>
            </div>
        </section>
    </header>
</template>

<style scoped>
.auth-profile-pic {
    width: 48px;
    height: 48px;
    border: 2px solid #78b3ce;
}

.collapsing {
    transition: all ease-in-out 1s;
}

.navbar {
    transition: all ease-in-out .5s;

    .nav-item {
        padding-left: 1rem;
        padding-right: 1rem;

        .nav-link {
            padding-left: 0;
            padding-right: 0;
            padding-bottom: 4px;

            &:hover {
                color: #9e4aed;
            }
        }

        .nav-link.active {
            color: #9e4aed;
            font-weight: bold;
            border-bottom: 2px solid #9e4aed;
        }
    }

    .category-dropdown {
        .category-dropdown-btn {
            border: 1px solid #ddd2e9;
            background-color: #f3e9fe;
        }

        .category-menu {
            height: 500px;
            overflow-y: auto;

            .category-menu-item {
                .dropdown-item {
                    border: 1px solid #fff;
                    border-left: 3px solid #fff;
                    padding: 6px 50px 6px 10px;
                    margin-top: 6px;
                    margin-bottom: 6px;
                    border-radius: 0.7rem;
                    transition: all 0.2s ease-in-out;

                    &:hover {
                        border-color: #9e4aed;
                        background-color: #f3e9fe;
                    }
                }
            }
        }
    }
}
</style>

<script setup>
import { useAuthStore } from "@/stores/auth";
import { useMasterStore } from "@/stores/master";
import Swal from "sweetalert2";
import { ref, onMounted, onUnmounted } from "vue";
import axios from "axios";
import { useRouter } from "vue-router";

const router = useRouter();

let toggleMenu = ref(false);

const authStore = useAuthStore();
const masterStore = useMasterStore();
const isLoggedIn = ref(false);

let categories = ref([]);

const fetchCategories = async () => {
    try {
        const response = await axios.get(`/categories`, {
            headers: {
                "Content-Type": "application/json",
                Accept: "application/json",
            },
            params: {
                items_per_page: 20,
                page_number: 1,
            },
        });
        categories.value = response.data.data.categories;
    } catch (error) {
        console.error("Error fetching categories:", error);
    }
};

onMounted(() => {
    fetchCategories();
    if (authStore.authToken) {
        isLoggedIn.value = true;
    }

    // Fetch master data
    if (!masterStore.data) {
        axios
            .get(`/master`, {
                headers: {
                    "Content-Type": "application/json",
                    Accept: "application/json",
                },
            })
            .then((response) => {
                masterStore.setMasterData(response.data.data.master);
            })
            .catch((error) => {
                console.error("Error fetching data:", error);
            });
    }
});

function logout() {
    Swal.fire({
        title: "Are you sure?",
        text: "Do you want to log out?",
        icon: "warning",
        showCancelButton: true,
        confirmButtonColor: "#3085d6",
        cancelButtonColor: "#d33",
        confirmButtonText: "Yes, log out!",
    }).then((result) => {
        if (result.isConfirmed) {
            authStore.clearAuthData();

            Swal.fire({
                title: "Logged Out!",
                text: "Log out successful.",
                showConfirmButton: false,
                icon: "success",
                timer: 1500,
            });
        }
        router.push("/");
    });
}
</script>