fix: 修復編譯錯誤,移除舊版Repository依賴注入

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
鄭沛軒 2025-09-24 01:29:24 +08:00
parent fd58f43b9b
commit 9c3178d104
2 changed files with 0 additions and 154 deletions

View File

@ -48,7 +48,6 @@ public static class ServiceCollectionExtensions
public static IServiceCollection AddRepositoryServices(this IServiceCollection services) public static IServiceCollection AddRepositoryServices(this IServiceCollection services)
{ {
services.AddScoped(typeof(IRepository<>), typeof(BaseRepository<>)); services.AddScoped(typeof(IRepository<>), typeof(BaseRepository<>));
services.AddScoped<IFlashcardRepository, SimpleFlashcardRepository>();
services.AddScoped<IUserRepository, UserRepository>(); services.AddScoped<IUserRepository, UserRepository>();
return services; return services;

View File

@ -1,153 +0,0 @@
using Microsoft.EntityFrameworkCore;
using DramaLing.Api.Data;
using DramaLing.Api.Models.Entities;
namespace DramaLing.Api.Repositories;
/// <summary>
/// 簡化的 Flashcard Repository 實作
/// </summary>
public class SimpleFlashcardRepository : BaseRepository<Flashcard>, IFlashcardRepository
{
public SimpleFlashcardRepository(DramaLingDbContext context, ILogger<SimpleFlashcardRepository> logger)
: base(context, logger)
{
}
public async Task<IEnumerable<Flashcard>> GetFlashcardsByUserIdAsync(Guid userId)
{
return await _dbSet.AsNoTracking().Where(f => f.UserId == userId).ToListAsync();
}
public async Task<IEnumerable<Flashcard>> GetFlashcardsByCardSetIdAsync(Guid cardSetId)
{
return await _dbSet.AsNoTracking().Where(f => f.CardSetId == cardSetId).ToListAsync();
}
public async Task<IEnumerable<Flashcard>> GetDueFlashcardsAsync(Guid userId, DateTime dueDate)
{
return await _dbSet.AsNoTracking()
.Where(f => f.UserId == userId && f.NextReviewDate <= dueDate)
.ToListAsync();
}
public async Task<IEnumerable<Flashcard>> GetFlashcardsByDifficultyAsync(Guid userId, string difficultyLevel)
{
return await _dbSet.AsNoTracking()
.Where(f => f.UserId == userId && f.DifficultyLevel == difficultyLevel)
.ToListAsync();
}
public async Task<IEnumerable<Flashcard>> GetRecentlyAddedAsync(Guid userId, int count)
{
return await _dbSet.AsNoTracking()
.Where(f => f.UserId == userId)
.OrderByDescending(f => f.CreatedAt)
.Take(count)
.ToListAsync();
}
public async Task<IEnumerable<Flashcard>> GetMostReviewedAsync(Guid userId, int count)
{
return await _dbSet.AsNoTracking()
.Where(f => f.UserId == userId)
.OrderByDescending(f => f.TimesReviewed)
.Take(count)
.ToListAsync();
}
public async Task<int> GetTotalFlashcardsCountAsync(Guid userId)
{
return await _dbSet.CountAsync(f => f.UserId == userId && !f.IsArchived);
}
public async Task<int> GetMasteredFlashcardsCountAsync(Guid userId)
{
return await _dbSet.CountAsync(f => f.UserId == userId && f.MasteryLevel >= 5);
}
public async Task<Dictionary<string, int>> GetFlashcardsByDifficultyStatsAsync(Guid userId)
{
var stats = await _dbSet
.Where(f => f.UserId == userId && !f.IsArchived)
.GroupBy(f => f.DifficultyLevel)
.Select(g => new { Level = g.Key, Count = g.Count() })
.ToDictionaryAsync(x => x.Level ?? "Unknown", x => x.Count);
return stats;
}
public async Task<IEnumerable<Flashcard>> SearchFlashcardsAsync(Guid userId, string searchTerm)
{
var term = searchTerm.ToLower();
return await _dbSet.AsNoTracking()
.Where(f => f.UserId == userId &&
(f.Word.ToLower().Contains(term) || f.Translation.ToLower().Contains(term)))
.ToListAsync();
}
public async Task<IEnumerable<Flashcard>> GetFavoriteFlashcardsAsync(Guid userId)
{
return await _dbSet.AsNoTracking()
.Where(f => f.UserId == userId && f.IsFavorite)
.ToListAsync();
}
public async Task<IEnumerable<Flashcard>> GetArchivedFlashcardsAsync(Guid userId)
{
return await _dbSet.AsNoTracking()
.Where(f => f.UserId == userId && f.IsArchived)
.ToListAsync();
}
public async Task<bool> BulkUpdateMasteryLevelAsync(IEnumerable<Guid> flashcardIds, int newMasteryLevel)
{
try
{
var ids = flashcardIds.ToList();
var flashcards = await _dbSet.Where(f => ids.Contains(f.Id)).ToListAsync();
foreach (var flashcard in flashcards)
{
flashcard.MasteryLevel = newMasteryLevel;
flashcard.UpdatedAt = DateTime.UtcNow;
}
return true;
}
catch
{
return false;
}
}
public async Task<bool> BulkUpdateNextReviewDateAsync(IEnumerable<Guid> flashcardIds, DateTime newDate)
{
try
{
var ids = flashcardIds.ToList();
var flashcards = await _dbSet.Where(f => ids.Contains(f.Id)).ToListAsync();
foreach (var flashcard in flashcards)
{
flashcard.NextReviewDate = newDate;
flashcard.UpdatedAt = DateTime.UtcNow;
}
return true;
}
catch
{
return false;
}
}
public async Task<IEnumerable<Flashcard>> GetFlashcardsWithIncludesAsync(Guid userId,
bool includeTags = false, bool includeStudyRecords = false)
{
var query = _dbSet.AsNoTracking().Where(f => f.UserId == userId);
if (includeTags)
{
query = query.Include(f => f.FlashcardTags!);
}
return await query.ToListAsync();
}
}