namespace EgwCoreLib.Lux.Data.Repository.Sales { public class CustomerRepository : BaseRepository, ICustomerRepository { #region Public Constructors public CustomerRepository(IDbContextFactory ctxFactory) : base(ctxFactory) { } #endregion Public Constructors #region Public Methods /// public async Task AddAsync(CustomerModel entity) { await using var dbCtx = await CreateContextAsync(); await dbCtx.DbSetCustomer.AddAsync(entity); return await dbCtx.SaveChangesAsync() > 0; } /// public async Task CountChildrenAsync(int CustomerID) { await using var dbCtx = await CreateContextAsync(); return await dbCtx.DbSetOffer.CountAsync(x => x.CustomerID == CustomerID); } /// public async Task DeleteAsync(CustomerModel entity) { await using var dbCtx = await CreateContextAsync(); dbCtx.DbSetCustomer.Remove(entity); return await dbCtx.SaveChangesAsync() > 0; } /// public async Task> GetAllAsync() { await using var dbCtx = await CreateContextAsync(); return await dbCtx.DbSetCustomer .AsNoTracking() .Include(o => o.OfferNav) .Include(o => o.OrderNav) .ToListAsync(); } /// public async Task GetByIdAsync(int CustomerID) { await using var dbCtx = await CreateContextAsync(); return await dbCtx.DbSetCustomer .Where(x => x.CustomerID == CustomerID) .Include(o => o.OfferNav) .Include(o => o.OrderNav) .FirstOrDefaultAsync(); } /// public async Task UpdateAsync(CustomerModel entity) { await using var dbCtx = await CreateContextAsync(); // Recuperiamo l'entità tracciata dal context var trackedEntity = await dbCtx.DbSetCustomer.FirstOrDefaultAsync(x => x.CustomerID == entity.CustomerID); if (trackedEntity != null) { // Aggiorna i valori dell'entità tracciata con quelli della nuova dbCtx.Entry(trackedEntity).CurrentValues.SetValues(entity); } else { dbCtx.DbSetCustomer.Update(entity); } return await dbCtx.SaveChangesAsync() > 0; } #endregion Public Methods } }