3.7 KiB
3.7 KiB
Context
此變更旨在為 VFX 專案管理系統新增一個「我的任務」(My Tasks) 頁面,讓用戶能夠在一個統一的視圖中查看所有專案中分配給自己的任務。目前用戶需要逐一進入每個專案才能看到被分配的任務,這對於同時管理多個專案的 Director、Coordinator 等角色而言效率較低。
現有系統已經具備:
- 完善的任務管理系統(Task entity with assignments)
- 專案內的任務頁面(使用 DataTable 元件)
- 基於角色的存取控制 (RBAC)
- JWT 認證機制
Goals / Non-Goals
Goals:
- 建立一個統一的「我的任務」頁面,展示所有分配給當前用戶的任務
- 重用現有的專案任務頁面 layout 與 DataTable 元件,確保 UI 一致性
- 支援按專案、狀態等條件篩選任務
- 支援任務排序功能
- 提供從任務列表直接導航到任務詳細頁面的功能
Non-Goals:
- 不會修改現有專案內的任務頁面行為
- 不會新增任務管理功能(如建立、編輯、刪除任務)- 這些應在專案上下文完成
- 不會提供跨專案的任務批量操作
Decisions
1. API 設計:獨立端點 vs 擴展現有端點
Decision: 建立獨立的 /api/tasks/my-tasks 端點
Rationale:
- 獨立端點可讓權限過濾更清晰(僅顯示用戶有權限存取的專案任務)
- 回應格式可針對 My Tasks 視圖優化(如包含專案資訊)
- 未來擴展(如分頁、進階篩選)更彈性
Alternative considered: 擴展現有的 /api/projects/{id}/tasks 端點
- 這個方法需要傳遞多個專案 ID,不適合跨專案查詢場景
2. 前端架構:新建元件 vs 重用現有元件
Decision: 重用現有的 ProjectTaskPage layout 與 DataTable 元件
Rationale:
- 確保 UI/UX 一致性,用戶在專案內和 My Tasks 頁面有相同體驗
- 減少開發時間和維護成本
- DataTable 元件已經支援排序、篩選、分頁等功能
Alternative considered: 建立全新的 MyTasksPage 元件
- 需要重複實作相同功能,增加維護負擔
3. 權限模型:僅顯示有權限的任務
Decision: API 僅返回用戶有存取權限的專案任務
Rationale:
- 符合最小權限原則
- 避免資安風險(用戶不應看到無權限專案的任務)
- 與現有 RBAC 系統整合
4. 資料庫查詢策略
Decision: 單一查詢取得所有任務(而非多次查詢)
Rationale:
- 減少網路往返次數
- 雖然查詢較複雜,但可通過 SQLAlchemy 優化
- 考量未來加入分頁以處理大量任務
Risks:
- [Risk] 大型系統中任務數量可能很大 → Mitigation: 實作分頁機制
- [Risk] 跨專案查詢效能 → Mitigation: 確保 task.assignee_id 和 task.project_id 有適當索引
Migration Plan
此變更為純新增功能,不需要資料遷移。部署步驟:
-
後端部署:
- 部署新 API 端點
/api/tasks/my-tasks - 確認任務查詢效能(如需要則新增資料庫索引)
- 部署新 API 端點
-
前端部署:
- 新增 My Tasks 頁面路由
- 確保導航選單有 My Tasks 入口
-
驗證:
- 測試不同角色用戶的 My Tasks 顯示正確性
- 驗證篩選、排序功能正常運作
- 確認權限控制正確(無權限專案的任務不顯示)
Open Questions
-
Q1: My Tasks 頁面是否需要顯示任務的詳細進度(如 shot/asset 進度)?
- 目前建議: 暫不包含,保持與專案任務頁面一致
-
Q2: 是否需要支援「我的最愛」或「追蹤中」的任務功能?
- 目前建議: 留待未來擴展
-
Q3: 如何處理任務數量眾多的效能問題?
- 建議: 採用分頁(預設 50 筆),並在未來根據需求考慮虛擬滾動