Files
CFDivePlatform/openspec/specs/admin-panel-ui/spec.md
T
a620906209 ad2c05779d feat:實作 Admin Panel — 平台管理後台
後端:
- AdminStatsController:總會員/教練/課程數統計 API
- AdminUserController:會員與教練列表、詳情、啟用/停用、教練驗證(toggle 反轉語意)
- AdminOfferController:全平台課程列表與刪除
- routes/api.php:新增 /api/admin/stats、members、providers、offers 等路由

前端(frontend/):
- adminAuth store、adminAxios(第三套獨立認證)
- /admin/* 路由群組 + requiresAdmin guard
- AdminNavBar、AdminLayout
- App.vue:isCoachPage → isBackofficePage(/coach/* 和 /admin/* 皆隱藏會員 NavBar)
- LoginView、DashboardView(統計卡片)
- MembersView、ProvidersView(含驗證操作)、OffersView(含刪除確認)

OpenSpec:
- 新增 specs:admin-auth / admin-user-management / admin-offer-management / admin-stats / admin-panel-ui
- 歸檔:openspec/changes/archive/2026-05-10-admin-panel

Co-Authored-By: Claude Sonnet 4.6 (1M context) <noreply@anthropic.com>
2026-05-10 04:07:13 +08:00

3.1 KiB
Raw Blame History

ADDED Requirements

Requirement: 管理員登入頁

前端 SHALL 提供 /admin/login 頁面,供管理員以 email/password 登入,成功後導向 /admin/dashboard

Scenario: 登入成功

  • WHEN 管理員填入正確帳密並送出
  • THEN 呼叫 POST /api/admin/logintoken 存入 adminAuth storelocalStorage key: admin_token),導向 /admin/dashboard

Scenario: 登入失敗

  • WHEN 帳密錯誤
  • THEN 頁面顯示錯誤訊息,不跳轉

Requirement: 儀表板(統計數據)

前端 SHALL 提供 /admin/dashboard 頁面(需 admin 登入),顯示平台核心統計數據。

Scenario: 載入統計數據

  • WHEN 管理員訪問 Dashboard
  • THEN 呼叫 GET /api/admin/stats,顯示總會員數、總教練數、總課程數三個數字卡片

Requirement: 會員管理頁

前端 SHALL 提供 /admin/members 頁面,列出所有會員,支援搜尋與啟用/停用操作。

Scenario: 載入會員列表

  • WHEN 管理員訪問此頁面
  • THEN 呼叫 GET /api/admin/members,以表格顯示姓名、email、註冊時間、帳號狀態

Scenario: 搜尋會員

  • WHEN 管理員在搜尋框輸入關鍵字
  • THEN?q= 重新呼叫 API,列表更新

Scenario: 切換帳號狀態

  • WHEN 管理員點擊啟用/停用按鈕
  • THEN 呼叫 PUT /api/admin/members/{id}/toggle-active,成功後按鈕狀態更新

Requirement: 教練管理頁

前端 SHALL 提供 /admin/providers 頁面,列出所有教練,支援搜尋、啟用/停用、驗證操作。

Scenario: 載入教練列表

  • WHEN 管理員訪問此頁面
  • THEN 呼叫 GET /api/admin/providers,顯示姓名、email、工作室名稱、驗證狀態、帳號狀態

Scenario: 切換驗證狀態

  • WHEN 管理員點擊驗證/取消驗證按鈕
  • THEN 呼叫 PUT /api/admin/providers/{id}/toggle-verified,成功後驗證狀態更新

Requirement: 課程管理頁

前端 SHALL 提供 /admin/offers 頁面,列出全平台課程,支援搜尋與刪除。

Scenario: 載入課程列表

  • WHEN 管理員訪問此頁面
  • THEN 呼叫 GET /api/admin/offers,顯示課程標題、地點、教練 ID、價格

Scenario: 刪除課程(含確認)

  • WHEN 管理員點擊刪除按鈕後確認
  • THEN 呼叫 DELETE /api/admin/offers/{id},成功後從列表移除

Requirement: Admin 路由守衛

前端 SHALL 對所有 /admin/* 路由(login 除外)加上 navigation guard,未登入時導向 /admin/login

Scenario: 未登入訪問後台頁面

  • WHEN 未登入使用者直接訪問 /admin/dashboard
  • THEN 自動導向 /admin/login

Requirement: Admin Layout 與導覽

前端 SHALL 提供 AdminLayout,包含 AdminNavBar(顯示管理員姓名、各功能連結、登出),所有 /admin/* protected 頁面套用此 Layout。/admin/* 路由不顯示會員 NavBar。

Scenario: 會員 NavBar 隱藏

  • WHEN 使用者訪問任何 /admin/* 路徑
  • THEN App.vue 不渲染會員 NavBar