dashboard.vue 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. <template>
  2. <div class="admin--dashboard">
  3. <div class="admin--dashboard-welcome">
  4. <h3>관리자 대시보드</h3>
  5. <p>고진모터스 AUDI 관리자 페이지에 오신 것을 환영합니다.</p>
  6. </div>
  7. <div class="admin--dashboard-stats">
  8. <div class="admin--stat-card">
  9. <div class="admin--stat-icon">📊</div>
  10. <div class="admin--stat-content">
  11. <h4>총 팝업</h4>
  12. <p class="admin--stat-number">{{ stats.popups }}</p>
  13. </div>
  14. </div>
  15. <div class="admin--stat-card">
  16. <div class="admin--stat-icon">🏢</div>
  17. <div class="admin--stat-content">
  18. <h4>총 지점</h4>
  19. <p class="admin--stat-number">{{ stats.branches }}</p>
  20. </div>
  21. </div>
  22. <div class="admin--stat-card">
  23. <div class="admin--stat-icon">👥</div>
  24. <div class="admin--stat-content">
  25. <h4>총 직원</h4>
  26. <p class="admin--stat-number">{{ stats.employees }}</p>
  27. </div>
  28. </div>
  29. <div class="admin--stat-card">
  30. <div class="admin--stat-icon">📝</div>
  31. <div class="admin--stat-content">
  32. <h4>브로셔 요청</h4>
  33. <p class="admin--stat-number">{{ stats.brochures }}</p>
  34. </div>
  35. </div>
  36. </div>
  37. <div class="admin--dashboard-recent">
  38. <h4>최근 활동</h4>
  39. <div class="admin--recent-list">
  40. <p class="admin--no-data">최근 활동 내역이 없습니다.</p>
  41. </div>
  42. </div>
  43. </div>
  44. </template>
  45. <script setup>
  46. import { ref, onMounted } from 'vue'
  47. definePageMeta({
  48. layout: 'admin',
  49. middleware: ['auth']
  50. })
  51. const stats = ref({
  52. popups: 0,
  53. branches: 0,
  54. employees: 0,
  55. brochures: 0
  56. })
  57. const { get } = useApi()
  58. const loadDashboardStats = async () => {
  59. const { data, error } = await get('/dashboard/stats')
  60. console.log('[Dashboard] API 응답:', { data, error })
  61. if (error) {
  62. console.error('[Dashboard] 통계 로드 실패:', error)
  63. return
  64. }
  65. // API 응답: { success: true, data: { popups, branches, employees, brochures } }
  66. if (data?.success && data?.data) {
  67. stats.value = data.data
  68. console.log('[Dashboard] 통계 로드 성공:', stats.value)
  69. }
  70. }
  71. onMounted(() => {
  72. loadDashboardStats()
  73. })
  74. </script>