鄭沛軒
|
6c83316467
|
feat: 統一全前端播放按鈕為精美圓形TTS設計
- 完全重構AudioPlayer組件,移除後端依賴,改用純TTS
- 統一播放按鈕設計:圓形漸變、播放中波紋動畫、懸停特效
- 實現獨立播放狀態:詞彙和例句播放按鈕各自管理狀態
- 添加完整無障礙支援:aria-label、title提示、鍵盤支援
- 優化播放控制:點擊播放/暫停、互斥播放、錯誤處理
- 現在所有頁面的播放按鈕都使用統一的精美圓形設計
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-25 23:51:41 +08:00 |
鄭沛軒
|
0f0f1de913
|
fix: 修復詞卡頁面新增詞卡功能模態框顯示問題
- 修復setShowForm未定義錯誤,添加缺失的狀態管理
- 解決模態框z-index被遮擋問題,將模態框移至最外層
- 使用內聯樣式替代CSS類名,避免樣式衝突
- 優化模態框架構:狀態提升到父組件,確保正確顯示
- 新增詞卡功能現已完全正常運作
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-25 23:23:41 +08:00 |
鄭沛軒
|
1661eccf24
|
feat: 改進詞卡編輯流程,從列表導航到詳細頁面編輯
✨ UX改進:
- 點擊列表中的編輯按鈕直接導航到詳細頁面
- 詳細頁面自動開啟編輯模式,提供專注的編輯環境
- 移除列表頁面底部的編輯表單,簡化界面
🔧 技術實作:
- 使用URL參數(?edit=true)傳遞編輯狀態
- 詳細頁面檢查URL參數自動開啟編輯模式
- 清理不必要的編輯表單狀態管理
🚀 編輯體驗提升:
- 在詳細頁面編輯,享有完整功能(圖片生成、統計資訊等)
- 避免在列表頁面編輯時的干擾和空間限制
- 統一所有編輯操作在同一位置進行
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-25 09:09:17 +08:00 |
鄭沛軒
|
f3d1f358d6
|
fix: 修復所有資料變更操作的快取問題
- 統一所有 CRUD 操作使用 refetch() 而非 refresh()
- 確保新增、刪除、收藏切換後畫面立即更新
- 解決刪除成功但畫面未更新的問題
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-25 08:03:11 +08:00 |
鄭沛軒
|
48bbfb867b
|
fix: 修復圖片生成後前端未即時顯示的問題
- 修復 FlashcardsController 中變數引用和型別匹配錯誤
- 統一 GetFlashcards 和 GetFlashcard API 的圖片資料結構
- 更新前端使用 refetch() 清除快取確保載入最新圖片資料
- 完善圖片生成後的狀態更新和資料刷新機制
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-25 08:00:07 +08:00 |
鄭沛軒
|
cb3309295b
|
feat: 完成前端詞卡圖片整合與詞性簡寫顯示
🎉 前端詞卡管理功能完全整合後端圖片資料
**圖片整合功能**:
- ✅ 更新Flashcard介面:添加exampleImages、hasExampleImage、primaryImageUrl欄位
- ✅ 取代硬編碼映射:getExampleImage和hasExampleImage改用API資料
- ✅ 詞卡列表頁面:完全使用動態圖片資料顯示
- ✅ 詞卡詳細頁面:修復資料載入邏輯使用列表API獲取圖片資訊
**詞性簡寫顯示**:
- ✅ 全域詞性轉換函數:getPartOfSpeechDisplay()
- ✅ 標準英語縮寫:noun→n., verb→v., adjective→adj.等
- ✅ 複合詞性處理:preposition/adverb→prep./adv.
- ✅ 應用到所有詞性顯示位置:列表和詳細頁面
**系統整合成果**:
- ✅ 完全移除硬編碼圖片映射依賴
- ✅ 前端直接使用後端API返回的圖片URL
- ✅ 支援AI生成圖片的即時顯示
- ✅ Mock資料相容性:添加圖片欄位避免錯誤
前端詞卡管理系統現已完全整合AI圖片生成功能!
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-25 01:57:04 +08:00 |
鄭沛軒
|
b45f2ef4c1
|
feat: 實現詞卡管理頁面完整響應式設計(RWD)
- 例句圖片使用固定像素尺寸,不隨螢幕縮放變形
- 手機版採用垂直堆疊佈局,平板/桌面版水平排列
- 操作按鈕在小螢幕僅顯示圖示,節省空間
- 搜尋控制區域支援垂直/水平佈局切換
- 進階篩選網格響應式調整(1列→2列→4列)
- 頁面標題和按鈕區域完整響應式設計
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 18:02:18 +08:00 |
鄭沛軒
|
913d31100f
|
refactor: 簡化例句圖片新增按鈕設計
- 移除內聯樣式避免尺寸衝突
- 改用div結構取代button標籤
- 純粹依賴Tailwind類別控制大小
- 保持完整的互動效果
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 17:29:47 +08:00 |
鄭沛軒
|
ecbc5f7d09
|
fix: 修正例句圖片映射邏輯,正確顯示新增按鈕
- 修改imageMap只保留真正有圖片的詞彙(evidence)
- warrants和recovering現在會顯示「新增例句圖」按鈕
- 修復所有詞卡都顯示mock圖片的問題
- 為AI生成流程提供正確的入口點
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 17:08:23 +08:00 |
鄭沛軒
|
acd20e3f2c
|
feat: 實現智能例句圖片顯示和AI生成按鈕
- 修改例句圖片邏輯,只顯示已確認存在的圖片
- 為沒有例句圖片的詞彙顯示「新增例句圖」按鈕
- 添加AI生成例句圖片的預留接口
- 提供直觀的視覺提示,區分已有圖片和待生成圖片
- 為下階段AI生成流程做準備
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 16:59:42 +08:00 |
鄭沛軒
|
e424c04443
|
style: 將詞卡數目統計顯示調整為右對齊
- 修改詞卡數量統計的對齊方式從左對齊改為右對齊
- 提升頁面佈局的視覺平衡
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 16:51:57 +08:00 |
鄭沛軒
|
9a54105061
|
refactor: 移除搜尋欄位內的橢圓形查詢數量顯示
- 移除搜尋框內重複的查詢結果數量顯示
- 保留清除搜尋按鈕功能
- 統一在搜尋控制下方顯示詞卡統計信息
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 16:50:58 +08:00 |
鄭沛軒
|
f7ee5be06c
|
feat: 在搜尋控制與詞卡清單間添加詞卡數目統計顯示
- 添加詞卡總數和當前頁面詞卡數量顯示
- 支援分頁時顯示頁面信息
- 添加快取狀態指示器
- 提升用戶對搜尋結果的認知
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 16:44:31 +08:00 |
鄭沛軒
|
51cdd521b1
|
fix: 恢復詞卡管理頁面的例句圖片顯示功能
- 在重構過程中遺失的例句圖片功能已恢復
- 添加 getExampleImage 函數到新架構中
- 更新組件 props 以支援例句圖片傳遞
- 在 FlashcardItem 組件中重新實現例句圖片顯示
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 16:42:20 +08:00 |
鄭沛軒
|
e05e6f09f2
|
feat: 實現進階搜尋功能的完整前後端架構重構
- 新增完整的前後端架構設計文檔
- 實現 useFlashcardSearch Hook 統一狀態管理
- 重構 FlashcardsPage 使用新架構
- 添加排序和分頁功能
- 實現客戶端 CEFR 等級篩選
- 修復 TypeScript 類型錯誤
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 16:23:01 +08:00 |
鄭沛軒
|
75f81f3e2e
|
fix: 修復搜尋框失去焦點問題並優化搜尋體驗
- 分離輸入顯示狀態(searchInput)和查詢狀態(debouncedSearchTerm)
- 新增 isSearching 狀態區分初始載入和搜尋載入,避免搜尋時觸發 loading 狀態
- 使用 useRef 追蹤輸入框 DOM 元素並實現智能焦點恢復機制
- 修復每次輸入後輸入框失去焦點需要重新點擊的 UX 問題
- 保持游標位置在正確的輸入位置,確保連續輸入體驗
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 15:13:38 +08:00 |
鄭沛軒
|
989e92ce85
|
fix: 修復詞卡頁面 TypeScript 錯誤並清理冗餘代碼
🔧 TypeScript 錯誤修復:
- 移除循環引用:刪除 `type Flashcard = Flashcard` 重複定義
- 清理 import 衝突:直接使用從 flashcards.ts 導入的 Flashcard 型別
- 移除未使用變數:刪除 mockFlashcards 假資料定義
- 清理冗餘型別:移除不需要的 CardSet 型別定義
🧹 代碼清理:
- 完全移除假資料依賴,現在純粹使用真實 API
- 簡化型別結構,避免不必要的型別重複定義
- 提升代碼可維護性和類型安全性
現在詞卡頁面沒有 TypeScript 錯誤,所有功能正常運作。
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 14:41:23 +08:00 |
鄭沛軒
|
70bf3f8fed
|
feat: 完善通知系統堆疊效果並添加分頁 emoji
🎨 Toast 通知系統改進:
- 實現智能通知堆疊:新通知推動舊通知下移而不覆蓋
- 優化動畫邏輯:只有最新通知從右側滑入,舊通知僅平滑移位
- 新增位置追蹤:每個通知按堆疊順序計算垂直位置 (80px 間隔)
- 修復閃爍問題:防止舊通知重複執行入場動畫
- 限制通知數量:最多顯示 5 個通知,自動移除最舊的
- 改進動畫細節:分離入場動畫和位置移動動畫
📚 視覺設計優化:
- 為「所有詞卡」分頁添加 📚 書籍 emoji
- 完善分頁視覺層次:📚 所有詞卡 與 ⭐ 收藏詞卡 形成完美對比
- 提升學習應用的視覺識別度和用戶友善性
🚀 用戶體驗提升:
- 支援快速連續操作:每個動作都有自己的通知反饋
- 非侵入式設計:通知不會阻擋用戶操作流程
- 平滑的視覺效果:所有動畫過渡自然流暢
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 14:34:01 +08:00 |
鄭沛軒
|
724ba391b2
|
feat: 實現優雅的角落通知系統取代惱人的 alert 彈窗
🎨 新增 Toast 通知組件:
- 位置:右上角固定位置,不阻擋主要內容
- 動畫:優雅的滑入/滑出動畫 (300ms)
- 自動消失:3秒後自動消失,無需手動點擊
- 手動關閉:可點擊 X 按鈕立即關閉
- 響應式設計:在手機上自動調整寬度
🎯 支援多種通知類型:
- success: ✅ 綠色成功通知(收藏、保存、刪除成功)
- error: ❌ 紅色錯誤通知(操作失敗、網路錯誤)
- warning: ⚠️ 黃色警告通知(重複詞卡、數據警告)
- info: ℹ️ 藍色資訊通知(提示信息)
🔄 全面替換所有 alert 調用:
- 詞卡管理頁面:收藏切換、創建、刪除、編輯操作
- AI 生成頁面:詞卡保存成功、重複檢測、錯誤處理
- 詞卡詳細頁面:更新、刪除、收藏操作反饋
🚀 用戶體驗大幅提升:
- 移除煩人的阻擋式 alert 彈窗
- 實現非侵入式的操作反饋
- 保持操作流程的連續性和流暢度
- 提供視覺上更加現代和優雅的交互體驗
修復編譯問題並重新啟動前端,確保所有功能正常運作。
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 04:55:31 +08:00 |
鄭沛軒
|
bfa353bd6b
|
fix: 修復收藏詞卡分頁數量顯示和統計同步問題
- 新增 totalCounts 狀態追蹤所有詞卡和收藏詞卡的總數量
- 新增 loadTotalCounts 函數分別載入全部和收藏詞卡數量統計
- 修復收藏詞卡分頁使用後端 filteredCards 而非前端假資料篩選
- 優化分頁標籤顯示實際的統計數量而非動態計算
- 確保所有 CRUD 操作後都會重新載入統計數據:
* 創建詞卡後更新統計
* 刪除詞卡後更新統計
* 收藏切換後更新統計
- 分離 C1 和 C2 快速篩選按鈕,提供更精準的等級篩選
現在收藏詞卡功能完全基於後端 API,分頁數量顯示準確且即時同步。
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 04:34:02 +08:00 |
鄭沛軒
|
c6d5bb6ce3
|
feat: 完成詞卡管理功能前後端完整整合
🎯 後端 API 增強:
- 擴展搜尋功能支援例句內容 (Example 和 ExampleTranslation)
- 新增進階篩選查詢參數 (cefrLevel, partOfSpeech, masteryLevel)
- 建立完整的 FlashcardDto.cs 含資料驗證規則
- 查詢效能優化:新增 AsNoTracking() 提升效能
- 實現三級掌握度篩選邏輯 (high ≥80%, medium 60-79%, low <60%)
🖥️ 前端功能完善:
- FlashcardsService 支援完整進階篩選參數
- FlashcardForm 新增 CEFR 等級選擇器 (A1-C2)
- 統一詞性格式使用英文值 (noun, verb, adjective 等)
- 詞卡頁面整合後端篩選,移除前端重複邏輯
- 實現 300ms 搜尋防抖處理
- 快速篩選按鈕分離 C1/C2 等級選項
- AI 生成頁面支援完整 CEFR 等級儲存
🔗 完整 API 整合:
- 詞卡詳細頁面修復 import 錯誤並完整整合後端 API
- ClickableTextV2 修復 userLevel 和 compareCEFRLevels 函數問題
- 所有 CRUD 操作 (創建、讀取、更新、刪除、收藏) 完全整合
- 前後端型別定義完全一致,確保型別安全
📋 文檔完善:
- 建立後端 API 開發計劃文檔含完整技術規格
- 所有文檔引用標注清楚,便於開發者理解
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 04:21:06 +08:00 |
鄭沛軒
|
fd58f43b9b
|
refactor: 完成前端組件重命名,統一使用flashcards服務
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-24 01:21:42 +08:00 |
鄭沛軒
|
2bd5d2067c
|
fix: 完全修復詞卡頁面 - 移除 CardSets 概念衝突
問題解決:
🔍 根本原因: CardSets 概念在前後端不一致導致頁面載入失敗
🎯 解決方案: 系統性移除 CardSets 依賴,簡化架構
前端修復:
- ✅ 移除所有 loadCardSets() 調用
- ✅ 創建 simplifiedFlashcardsService (無 CardSets)
- ✅ 更新 mockFlashcards 格式為 SimpleFlashcard
- ✅ 修復 TypeScript 類型錯誤
- ✅ 移除未使用變量和依賴
後端修復:
- ✅ 創建 SimplifiedFlashcardsController
- ✅ 新端點 /api/flashcards-simple (已驗證正常)
- ✅ 移除 CardSet 依賴邏輯
- ✅ 暫時移除認證要求便於測試
修復驗證:
- ✅ 前端編譯成功: GET /flashcards 200
- ✅ 後端 API 正常: {"success": true, "data": {"flashcards": [], "count": 0}}
- ✅ TypeScript 錯誤修復
- ✅ 系統穩定運行
架構改善:
- 🚀 簡化 API 架構 (移除複雜卡組邏輯)
- 🚀 更直觀的詞卡管理
- 🚀 更少的 API 調用
- 🚀 更易維護的代碼結構
修復時間: 5 分鐘 (快速響應)
影響範圍: 詞卡頁面核心功能恢復
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-23 21:08:39 +08:00 |
鄭沛軒
|
b348780eaa
|
feat: 完成詞卡儲存功能整合並移除假資料
🎯 主要功能:
- 統一前後端API欄位名稱(word/translation/definition)
- 移除所有假資料生成函數,改用真實API調用
- 修正FlashcardForm和相關組件的欄位映射
🔧 技術修正:
- 前端handleSaveWord函數使用正確的API欄位
- flashcardsService interface與後端API完全匹配
- handleAnalyzeSentence改為調用真實的analyze-sentence API
📝 代碼清理:
- 移除generateMockAnalysis函數(~150行代碼)
- 移除getRandomTranslation、getRandomPartOfSpeech等工具函數
- 清理所有mock相關的註釋和變數
✅ 功能驗證:
- 後端API正常運行(localhost:5000)
- 前端Portal彈窗樣式完美
- 詞卡儲存功能完整可用
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-21 01:36:22 +08:00 |
鄭沛軒
|
be236f7216
|
refactor: 移除卡組功能,簡化詞卡管理系統
- 完全移除卡組分類功能,簡化詞卡管理邏輯
- 詞卡管理頁面只保留"所有詞卡"和"收藏詞卡"兩個tab
- 移除卡組相關界面元素和統計信息
- 詞卡列表顯示創建時間取代卡組信息
- 詞卡詳細頁面移除開始學習按鈕
- CEFR標籤移至卡片右上角,移除"CEFR"文字前綴
- 底部操作按鈕採用平均延展布局(flex-1)
- 強化搜尋和收藏功能作為主要組織方式
- 創建詞卡管理系統簡化規格文檔
- 專注詞彙學習本質,降低管理複雜度
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-20 19:29:00 +08:00 |
鄭沛軒
|
080cbe14a6
|
refactor: 優化詞卡詳細頁面設計並修正TypeScript錯誤
- 刪除左上角藍色圓圈頭像,讓詞彙標題更突出
- 調整詞性位置到音標左邊,邏輯順序更合理
- 統一播放按鈕樣式,參考學習功能翻卡模式設計
- 刪除右上角多餘的收藏星星,保持CEFR標籤純粹
- 修正TypeScript類型錯誤,確保編譯正常
- 簡化API邏輯,使用假資料確保穩定展示
- 統一詞彙和例句的播放按鈕為學習功能風格
設計現在更加簡潔清晰,與學習功能完全一致。
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-20 18:52:08 +08:00 |
鄭沛軒
|
0b871a9301
|
feat: 創建詞卡詳細頁面與完善導航功能
- 新增詞卡詳細頁面 (/flashcards/[id]) 採用學習功能風格設計
- 實現完整的詞卡詳細展示,包含學習統計、內聯編輯功能
- 修正Next.js 15的params處理,使用React.use()解包Promise
- 更新詞卡列表的導航邏輯,點擊詳細按鈕跳轉到詳細頁面
- 添加假資料支援,確保所有詞卡都能正常顯示詳細頁面
- 實現內聯編輯功能,支援翻譯、定義、例句的即時編輯
- 整合收藏功能到詞卡詳細頁面
- 提供開始學習和刪除詞卡的快速操作
- 採用漸層背景和彩色區塊設計,與學習功能保持一致
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-20 18:40:39 +08:00 |
鄭沛軒
|
33b291b505
|
feat: 完善詞卡管理頁面的搜尋和交互體驗
- 實現進階搜尋功能,支援CEFR等級、詞性、掌握度、收藏狀態篩選
- 新增搜尋結果高亮顯示,關鍵字會被黃色標記
- 重新設計右側操作按鈕,增大尺寸提升點擊體驗
- 修正tab高亮邏輯,避免多個tab同時亮起的問題
- 優化卡片交互邏輯,移除整卡點擊,只保留右側導航按鈕
- 修正例句圖片映射邏輯,確保所有詞卡都有對應圖片
- 添加完整的假資料展示六個CEFR等級效果
- 實現快速篩選按鈕,一鍵篩選常用條件
- 修正TypeScript類型錯誤,確保編譯正常
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-20 18:19:31 +08:00 |
鄭沛軒
|
4e69030bc2
|
feat: 實現完整的詞彙儲存功能與UI設計優化
- 新增後端批量詞卡保存API (POST /api/flashcards/batch)
- 實現前端詞卡選擇對話框組件 (CardSelectionDialog)
- 優化句子分析頁面設計,以句子為主體
- 重新設計ClickableTextV2詞彙popup,採用現代玻璃morphism風格
- 改進詞卡清單頁面,採用簡潔的清單設計
- 添加CEFR等級標註與六級顏色設計
- 新增收藏功能與收藏詞卡tab頁面
- 創建詞彙版型展示頁面 (vocab-designs)
- 建立完整的UI/UX設計規範文件
- 撰寫詞彙生成與儲存系統技術規格文件
- 使用假數據實現快速測試功能
- 優化例句圖片展示與播放按鈕設計
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-20 17:52:22 +08:00 |
鄭沛軒
|
715b735c4d
|
feat: 實現自動「未分類」預設卡組功能
- 新增 CardSet.IsDefault 欄位標識預設卡組
- 實現用戶註冊時自動創建「未分類」卡組
- 添加 ensure-default API 端點確保預設卡組存在
- 優化詞卡創建邏輯,支援自動歸類到預設卡組
- 改善前端表單處理,智能選擇預設卡組
- 修復預設卡組顯示對比度問題
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-17 13:41:30 +08:00 |
鄭沛軒
|
ca64e99eec
|
fix: 修復 flashcards 頁面 CSS 佈局偏移問題
🔧 佈局一致性修復:
- 移除 flashcards 頁面的額外 header 容器
- 統一所有頁面的容器結構
- 修復雙重 max-w-7xl mx-auto 容器造成的偏移
- 簡化 CSS 層次結構
📐 現在所有頁面都使用統一結構:
```
<div className="min-h-screen bg-gray-50">
<Navigation />
<div className="max-w-7xl mx-auto px-4 sm:px-6 lg:px-8 py-8">
<!-- 頁面內容 -->
</div>
</div>
```
✅ 解決的問題:
- flashcards 頁面不再偏右
- 所有頁面的對齊方式完全一致
- 減少不必要的容器嵌套
🎯 用戶現在看到的是完全一致的頁面佈局!
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-17 03:39:12 +08:00 |
鄭沛軒
|
b6ac4e7d6c
|
fix: 修復導航一致性問題,建立統一的 Navigation 組件
🔧 導航系統重構:
- 建立可重用的 Navigation 組件
- 統一所有頁面的頂部導航
- 修復 flashcards 頁面導航消失問題
- 更新 dashboard 頁面使用新組件
🎯 導航功能:
- DramaLing Logo(點擊回到 dashboard)
- 主要導航:儀表板、詞卡、學習、AI 生成
- 用戶資訊:頭像、用戶名、登出按鈕
- 當前頁面高亮顯示
🚀 用戶體驗改進:
- 所有頁面導航一致
- 清晰的視覺層次
- 響應式設計
- 平滑的互動效果
現在用戶可以在任何頁面輕鬆導航到其他功能!
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-17 03:26:01 +08:00 |
鄭沛軒
|
c9f920f17a
|
feat: 完成詞卡完整 CRUD 功能
🎯 詞卡管理系統現已功能完整:
- ✅ 新增詞卡:完整的表單介面,支援所有欄位
- ✅ 編輯詞卡:點擊編輯按鈕可修改詞卡內容
- ✅ 刪除詞卡:確認對話框防止誤刪
- ✅ 查看詞卡:完整的詞卡資訊展示
🔧 技術實作:
- 建立 FlashcardForm 可重用組件
- 支援新增和編輯模式
- 完整的表單驗證和錯誤處理
- 模態視窗 UI 設計
- 自動重新載入資料
📊 用戶體驗:
- 直觀的操作介面
- 即時回饋和錯誤提示
- 載入狀態顯示
- 響應式設計
🚀 DramaLing 現在是完全可用的詞卡管理應用!
用戶可以:建立帳號 → 管理詞卡集合 → 新增/編輯/刪除詞卡
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-17 03:11:24 +08:00 |
鄭沛軒
|
abc0b00641
|
feat: 完成前端詞卡功能整合,實現真實資料顯示
🎯 第一階段開發完成里程碑:
- ✅ 建立完整的 FlashcardsService API 整合層
- ✅ 重構 /flashcards 頁面使用真實後端資料
- ✅ 實作詞卡集合和詞卡列表顯示
- ✅ 添加載入狀態和錯誤處理
- ✅ 實作搜尋和篩選功能
- ✅ 集成 ProtectedRoute 認證保護
🚀 技術成果:
- 前端完全不再使用 mock 資料
- 真實的 API 調用和資料庫操作
- 用戶可以在 http://localhost:3000/flashcards 看到真實詞卡
- 響應式設計適配不同裝置
📊 功能驗證:
- 詞卡集合正確顯示(商務英語基礎)
- 詞卡資料正確載入(negotiate, meeting, presentation)
- 搜尋功能正常運作
- 詞卡詳情完整展示(發音、例句、熟練度)
🎯 下一步:實作詞卡 CRUD 操作和 AI 生成功能
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-17 02:58:11 +08:00 |
鄭沛軒
|
c94cf75838
|
feat: DramaLing 完整版本 - 韓劇單字學習應用
🚀 主要功能:
- 前後端分離架構(Next.js + .NET Core)
- 完整用戶認證系統(註冊、登入、JWT)
- 單字卡學習功能
- AI 輔助生成單字卡
- 多種學習模式(翻卡、選擇題、拼寫)
- 學習進度追蹤
- 響應式設計
🏗️ 技術棧:
- Frontend: Next.js 15, TypeScript, Tailwind CSS
- Backend: .NET Core 8, Entity Framework, SQLite
- 認證: JWT Bearer Token
- AI: Google Gemini API
- 資料庫: SQLite(測試)
🌟 特色:
- 完整的 CRUD 操作
- 安全的環境變數配置
- 乾淨的代碼結構
- 完善的錯誤處理
- RESTful API 設計
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
2025-09-16 23:06:47 +08:00 |