TigerEmu/Game/Catalogue/CatalogueManager.cs

26 lines
815 B
C#

using Microsoft.Extensions.Logging;
using Tiger.Storage;
namespace Tiger.Game.Catalogue;
public class CatalogueManager : ICatalogueManager
{
private readonly IRepository<CataloguePage> _pagesRepository;
private readonly ILogger<ICatalogueManager> _logger;
public IDictionary<int, CataloguePage> Pages { get; private set; }
public CatalogueManager(IRepository<CataloguePage> pagesRepository, ILogger<ICatalogueManager> logger)
{
_pagesRepository = pagesRepository;
_logger = logger;
Pages = new Dictionary<int, CataloguePage>();
}
public async Task LoadPagesAsync()
{
Pages = (await _pagesRepository.FindByAsync()).ToDictionary(p => p.Id, p => p);
_logger.LogInformation("Loaded {Count} catalogue pages", Pages.Count);
}
}