feat: Add dashboard, course discovery, and quiz pages to introduce core e-learning functionalities.

This commit is contained in:
supalerk-ar66 2026-01-21 17:14:58 +07:00
parent f6bbd60f2b
commit db9ff684ae
3 changed files with 38 additions and 269 deletions

View file

@ -105,7 +105,7 @@ onUnmounted(() => {
<div class="text-center mb-10">
<h2 class="text-[32px] font-black text-slate-900 dark:text-white mb-2 tracking-tight">แบบทดสอบทายบท</h2>
<p class="text-[13px] font-bold text-slate-500 dark:text-slate-400 uppercase tracking-widest leading-none">องตนการออกแบบ UX/UI</p>
<p class="text-[13px] font-bold text-slate-500 dark:text-slate-400 uppercase tracking-widest leading-none">ตรยมความพรอมกอนเรมทำ</p>
</div>
<!-- Instruction Box -->
@ -116,27 +116,11 @@ onUnmounted(() => {
<ul class="space-y-4">
<li class="flex items-start gap-3">
<span class="w-1.5 h-1.5 rounded-full bg-blue-500 mt-1.5 flex-shrink-0"/>
<span class="text-[14px] text-slate-600 dark:text-slate-300 font-medium leading-relaxed">แบบทดสอบนงหมด <strong class="text-slate-900 dark:text-white">10 </strong></span>
</li>
<li class="flex items-start gap-3">
<span class="w-1.5 h-1.5 rounded-full bg-blue-500 mt-1.5 flex-shrink-0"/>
<span class="text-[14px] text-slate-600 dark:text-slate-300 font-medium leading-relaxed">เกณฑการผาน <strong class="text-slate-900 dark:text-white">80% นไป</strong></span>
</li>
<li class="flex items-start gap-3">
<span class="w-1.5 h-1.5 rounded-full bg-blue-500 mt-1.5 flex-shrink-0"/>
<span class="text-[14px] text-slate-600 dark:text-slate-300 font-medium leading-relaxed">เวลาในการทำ: <strong class="text-slate-900 dark:text-white">30 นาท</strong></span>
</li>
<li class="flex items-start gap-3">
<span class="w-1.5 h-1.5 rounded-full bg-blue-500 mt-1.5 flex-shrink-0"/>
<span class="text-[14px] text-slate-600 dark:text-slate-300 font-medium leading-relaxed">ไมสามารถหยดเวลาชวคราวไดเมอเรมทำแบบทดสอบแล</span>
<span class="text-[14px] text-slate-600 dark:text-slate-300 font-medium leading-relaxed">งใจทำแบบทดสอบเพอวดผลการเรยนร</span>
</li>
</ul>
</div>
<div class="text-[13px] font-black text-slate-400 dark:text-slate-500 mb-10 flex items-center justify-between px-2">
<span>คะแนนท: <span class="text-slate-900 dark:text-white">-</span></span>
</div>
<!-- Action Button -->
<button
class="w-full py-5 bg-blue-600 hover:bg-blue-500 text-white rounded-[20px] font-black text-[14px] tracking-wider transition-all shadow-xl shadow-blue-600/20 active:scale-[0.98]"
@ -147,154 +131,27 @@ onUnmounted(() => {
</div>
</div>
<!-- 2. TAKING SCREEN -->
<div v-if="currentScreen === 'taking'" class="w-full max-w-[840px] animate-fade-in py-12">
<div class="bg-white dark:!bg-[#1e293b] border border-slate-200 dark:border-white/5 rounded-[32px] p-8 md:p-14 shadow-2xl backdrop-blur-sm">
<div class="flex items-center justify-between mb-10 pb-6 border-b border-slate-100 dark:border-white/5">
<div>
<div class="text-[10px] font-black text-slate-400 dark:text-slate-500 uppercase tracking-[0.2em] mb-2">อท 1 จาก 10</div>
<!-- Progress Line -->
<div class="w-48 h-1 bg-slate-100 dark:bg-white/5 rounded-full overflow-hidden">
<div class="h-full bg-blue-500" style="width: 10%;"/>
</div>
</div>
<!-- Timer Display -->
<div class="flex items-center gap-3 px-5 py-2.5 bg-amber-50 dark:bg-amber-500/10 border border-amber-200 dark:border-amber-500/20 rounded-2xl text-amber-600 dark:text-amber-500">
<span class="text-sm"></span>
<span class="text-[15px] font-black font-mono tracking-widest">{{ timerDisplay }}</span>
</div>
</div>
<div class="mb-12">
<h2 class="text-[22px] font-black text-slate-900 dark:text-white leading-tight mb-8">อใดตอไปนอหลกการแรกของ User Experience (UX) ตามโมเดลของ Peter Morville?</h2>
<!-- Question Options -->
<div class="space-y-4">
<button v-for="i in 4" :key="i" class="w-full p-6 text-left rounded-2xl border border-slate-200 dark:border-white/5 bg-slate-50 dark:bg-white/5 hover:bg-white hover:border-blue-500 hover:shadow-lg dark:hover:bg-white/10 transition-all flex items-center gap-4 group">
<div class="w-6 h-6 rounded-full border-2 border-slate-300 dark:border-slate-700 flex items-center justify-center group-hover:border-blue-500 transition-colors">
<div class="w-2.5 h-2.5 rounded-full bg-blue-500 opacity-0 group-focus:opacity-100"/>
</div>
<span class="text-[15px] font-medium text-slate-700 dark:text-slate-300 group-hover:text-slate-900 dark:group-hover:text-white">วเลอกท {{ i }} สำหรบคำตอบทเปนไปได</span>
</button>
</div>
</div>
<div class="flex justify-between items-center">
<button class="px-8 py-3 text-slate-400 dark:text-slate-500 font-bold hover:text-slate-600 dark:hover:text-white transition-colors">อนกล</button>
<button class="px-10 py-4 bg-blue-600 text-white rounded-2xl font-black text-sm shadow-lg shadow-blue-600/20" @click="submitQuiz(false)">ถัดไป</button>
</div>
</div>
<!-- 2. TAKING SCREEN (Placeholder for Real API) -->
<div v-if="currentScreen === 'taking'" class="w-full max-w-[840px] animate-fade-in py-12 text-center">
<div class="bg-white dark:!bg-[#1e293b] rounded-[32px] p-10 shadow-xl">
<h2 class="text-xl font-bold mb-4">วนนอยระหวางการเชอมตอกบระบบขอสอบจร</h2>
<p class="text-slate-500">ระบบขอสอบจะสามารถใชงานไดเมอมการเชอมต API สมบรณ</p>
<button @click="currentScreen = 'result'" class="mt-8 btn btn-primary">ามไปหนาผลลพธ (จำลอง)</button>
</div>
</div>
<!-- 3. RESULT SCREEN -->
<!-- 3. RESULT SCREEN (Empty/Placeholder) -->
<div v-if="currentScreen === 'result'" class="w-full max-w-[640px] animate-fade-in py-12">
<div class="bg-white dark:!bg-[#1e293b] border border-slate-200 dark:border-white/5 rounded-[40px] p-10 md:p-14 shadow-2xl text-center backdrop-blur-sm">
<!-- Trophy Icon -->
<div class="w-20 h-20 rounded-full bg-emerald-500/10 border border-emerald-500/20 flex items-center justify-center mx-auto mb-10 shadow-inner">
<span class="text-4xl">🏆</span>
</div>
<h2 class="text-[32px] font-black text-slate-900 dark:text-white mb-2 tracking-tight">นดวยคณสอบผาน!</h2>
<p class="text-[13px] font-bold text-slate-500 dark:text-slate-500 uppercase tracking-widest mb-12">ณทำคะแนนไดยอดเยยมและผานเกณฑการทดสอบ</p>
<!-- Stats Boxes -->
<div class="grid grid-cols-3 gap-4 mb-14">
<div class="p-6 rounded-[24px] bg-slate-50 dark:bg-[#0b121f]/60 border border-slate-100 dark:border-white/5 shadow-inner">
<div class="text-[9px] font-black text-slate-400 dark:text-slate-500 uppercase tracking-[0.2em] mb-3">คะแนน</div>
<div class="text-[20px] font-black text-blue-600 dark:text-blue-500">90%</div>
</div>
<div class="p-6 rounded-[24px] bg-slate-50 dark:bg-[#0b121f]/60 border border-slate-100 dark:border-white/5 shadow-inner">
<div class="text-[9px] font-black text-slate-400 dark:text-slate-500 uppercase tracking-[0.2em] mb-3">ตอบถ</div>
<div class="text-[20px] font-black text-emerald-600 dark:text-emerald-500">9/10</div>
</div>
<div class="p-6 rounded-[24px] bg-slate-50 dark:bg-[#0b121f]/60 border border-slate-100 dark:border-white/5 shadow-inner">
<div class="text-[9px] font-black text-slate-400 dark:text-slate-500 uppercase tracking-[0.2em] mb-3">เวลาทใช</div>
<div class="text-[20px] font-black text-slate-900 dark:text-white">12:45</div>
</div>
</div>
<!-- Buttons -->
<div class="space-y-4">
<button
class="w-full py-5 bg-blue-600 hover:bg-blue-500 text-white rounded-[24px] font-black text-[14px] tracking-wider transition-all shadow-xl shadow-blue-600/20"
@click="showReview"
>
เฉลย
</button>
<NuxtLink
to="/dashboard"
class="w-full py-5 bg-slate-100 dark:bg-[#1e293b] hover:bg-slate-200 dark:hover:bg-[#253347] text-slate-600 dark:text-slate-400 hover:text-slate-900 dark:hover:text-white rounded-[24px] font-black text-[14px] tracking-wider transition-all border border-slate-200 dark:border-white/5 block"
>
กลบไปหนาหล
</NuxtLink>
</div>
</div>
</div>
<!-- 4. REVIEW SCREEN -->
<div v-if="currentScreen === 'review'" class="w-full max-w-[840px] animate-fade-in py-12">
<div class="mb-10 flex items-center justify-between">
<h2 class="text-[24px] font-black text-slate-900 dark:text-white tracking-tight">เฉลยและทบทวนรายข</h2>
<button class="text-[13px] font-black text-slate-400 hover:text-slate-600 dark:hover:text-white transition-colors flex items-center gap-2" @click="currentScreen = 'result'"/>
</div>
<div class="space-y-6">
<!-- Review Item: Correct Answer -->
<div class="bg-white dark:bg-[#1e293b]/40 border border-emerald-500/20 rounded-[32px] p-8 md:p-10 shadow-xl backdrop-blur-sm relative overflow-hidden group">
<div class="absolute left-0 top-0 bottom-0 w-1.5 bg-emerald-500"/>
<div class="flex items-center gap-2 mb-6 text-[10px] font-black uppercase tracking-widest">
<span class="text-emerald-500"> ตอบถ</span>
<span class="text-slate-600 dark:text-slate-500"> อท 1</span>
</div>
<h3 class="text-[18px] font-black text-slate-900 dark:text-white leading-tight mb-8">อใดตอไปนอธบายกระบวนการออกแบบ "Double Diamond" ได?</h3>
<div class="space-y-3 mb-8">
<div class="p-5 rounded-2xl bg-emerald-50 dark:bg-emerald-500/5 border border-emerald-500/20 text-emerald-600 dark:text-emerald-400 font-bold text-[14px] flex items-center justify-between">
<span>กระบวนการแตกประเดนเพอคนหา/ฒนา และสรปประเดนเพอกำหนด/งมอบ</span>
<span class="text-xs"></span>
</div>
</div>
<div class="bg-slate-50 dark:bg-[#0b121f]/60 p-6 rounded-2xl border border-slate-100 dark:border-white/5">
<h4 class="text-[11px] font-black text-slate-400 dark:text-slate-500 uppercase tracking-widest mb-3">คำอธบาย:</h4>
<p class="text-[14px] text-slate-600 dark:text-slate-400 leading-relaxed font-medium">
Double Diamond ประกอบดวย 4 นตอนหล: Discover, Define, Develop และ Deliver งเนนการสลบกนระหวางความคดสรางสรรคแบบเปดกวาง (Divergent) และการคดกรองเพอใหไดอสร (Convergent)
</p>
</div>
</div>
<!-- Review Item: Incorrect Answer -->
<div class="bg-white dark:bg-[#1e293b]/40 border border-red-500/20 rounded-[32px] p-8 md:p-10 shadow-xl backdrop-blur-sm relative overflow-hidden">
<div class="absolute left-0 top-0 bottom-0 w-1.5 bg-red-500"/>
<div class="flex items-center gap-2 mb-6 text-[10px] font-black uppercase tracking-widest">
<span class="text-red-500"> ตอบผ</span>
<span class="text-slate-600 dark:text-slate-500"> อท 2</span>
</div>
<h3 class="text-[18px] font-black text-slate-900 dark:text-white leading-tight mb-8">เปาหมายหลกของ User Research ออะไร?</h3>
<div class="space-y-3 mb-8">
<div class="p-5 rounded-2xl bg-red-50 dark:bg-white/5 border border-red-500/30 text-red-500 dark:text-red-400 font-medium text-[14px]">
<span class="opacity-50 line-through">เพอใหแนใจวาดไซนทำออกมาสวยงามท</span>
<span class="ml-2 text-[10px] bg-red-500/20 px-2 py-0.5 rounded text-red-600 dark:text-red-500">คำตอบของค</span>
</div>
<div class="p-5 rounded-2xl bg-emerald-50 dark:bg-emerald-500/5 border border-emerald-500/20 text-emerald-600 dark:text-emerald-400 font-bold text-[14px] flex items-center justify-between">
<span>เพอทำความเขาใจความตองการ ญหา และพฤตกรรมของผใชแทจร</span>
<span class="text-[10px] bg-emerald-500/20 px-2 py-0.5 rounded text-emerald-600 dark:text-emerald-400">คำตอบทกตอง</span>
</div>
</div>
<div class="bg-slate-50 dark:bg-[#0b121f]/60 p-6 rounded-2xl border border-slate-100 dark:border-white/5">
<h4 class="text-[11px] font-black text-slate-400 dark:text-slate-500 uppercase tracking-widest mb-3">คำอธบาย:</h4>
<p class="text-[14px] text-slate-600 dark:text-slate-400 leading-relaxed font-medium">
User Research ไมใชแคการดความสวยงาม แตอการหา "Insights" เพอนำมาแกญหาใหตรงจ ลดความเสยงในการสรางของทใชงานไมไดองการจรงๆ
</p>
</div>
</div>
</div>
<div class="mt-12 flex justify-center">
<button class="px-10 py-4 bg-slate-100 hover:bg-slate-200 dark:bg-white/5 dark:hover:bg-white/10 text-slate-600 dark:text-slate-400 hover:text-slate-900 dark:hover:text-white rounded-[20px] font-black text-sm border border-slate-200 dark:border-white/5 transition-all" @click="currentScreen = 'result'">กลบไปหนาสรปผล</button>
<div class="bg-white dark:!bg-[#1e293b] rounded-[40px] p-10 shadow-2xl text-center">
<h2 class="text-2xl font-black mb-4">จบการทำแบบทดสอบ</h2>
<div class="space-y-4 mt-8">
<NuxtLink
to="/classroom/learning"
class="w-full py-5 bg-slate-100 text-slate-600 rounded-[24px] font-black text-[14px] block"
>
กลบไปหนาบทเรยน
</NuxtLink>
</div>
</div>
</div>
</main>