using Microsoft.EntityFrameworkCore; using System; using System.Collections.Generic; using System.Linq; using UnivateProperties_API.Context; using UnivateProperties_API.Model.Timeshare; namespace UnivateProperties_API.Repository.Timeshare { public class SeasonRepository : IRepository { private readonly DataContext _dbContext; public SeasonRepository(DataContext dbContext) { _dbContext = dbContext; } public List Get(Func where) { return _dbContext.Seasons.Where(where).ToList(); } public List GetAll() { return _dbContext.Seasons.ToList(); } public Season GetDetailed(Func first) { var item = _dbContext.Seasons.FirstOrDefault(first); return item; } public List GetDetailedAll() { return GetAll(); } public void Insert(Season item) { item.Id = NewId(); _dbContext.Add(item); Save(); } public void Insert(IEnumerable items) { int id = NewId(); foreach (var item in items) { item.Id = id; _dbContext.Add(item); id += 1; } Save(); } public void Remove(Season item) { var i = _dbContext.Seasons.Find(item); _dbContext.Seasons.Remove(i); Save(); } public void Remove(IEnumerable items) { foreach (var item in items) { var i = _dbContext.Seasons.Find(item); _dbContext.Seasons.Remove(i); } Save(); } public void RemoveAtId(int item) { var i = _dbContext.Seasons.Find(item); _dbContext.Seasons.Remove(i); Save(); } public void Save() { _dbContext.SaveChanges(); } public void Update(Season item) { _dbContext.Entry(item).State = EntityState.Modified; Save(); } public int NewId() { int id = 0; if (_dbContext.Seasons.Count() > 0) { id = _dbContext.Seasons.Max(x => x.Id); } id += 1; return id; } } }