elearning/Frontend-Learner/app.vue

32 lines
1.3 KiB
Vue
Raw Normal View History

2026-01-14 15:15:31 +07:00
<script setup>
// ดึงฟังก์ชันจัดการ Authentication
2026-01-14 15:15:31 +07:00
const { fetchUserProfile, isAuthenticated } = useAuth()
// เมื่อ App เริ่มทำงาน (Mounted)
2026-01-14 15:15:31 +07:00
onMounted(() => {
2026-01-23 13:27:19 +07:00
// 1. หากผู้ใช้ Login ค้างไว้ (มี Token) ให้ดึงข้อมูล Profile ล่าสุดทันที
2026-01-14 15:15:31 +07:00
if (isAuthenticated.value) {
fetchUserProfile()
}
2026-01-23 13:27:19 +07:00
// 2. ตรวจสอบและคืนค่า Theme (Dark/Light) จาก LocalStorage
const savedTheme = localStorage.getItem('theme')
if (savedTheme === 'dark' || (!savedTheme && window.matchMedia('(prefers-color-scheme: dark)').matches)) {
document.documentElement.classList.add('dark')
} else {
document.documentElement.classList.remove('dark')
}
2026-01-14 15:15:31 +07:00
})
</script>
2026-01-13 10:46:40 +07:00
<template>
<!-- แสดง Loader ระหวางเปลยนหน หรอโหลดขอม -->
2026-01-13 12:55:21 +07:00
<GlobalLoader />
<!-- NuxtLayout: แสดง Layout กำหนดในแตละเพจ (default: layouts/default.vue) -->
2026-01-13 10:46:40 +07:00
<NuxtLayout>
<!-- NuxtPage: แสดงเนอหาของเพจปจจ (ตาม URL routng) -->
2026-01-13 10:46:40 +07:00
<NuxtPage />
</NuxtLayout>
</template>