using Microsoft.EntityFrameworkCore;
using RouteGuideContracts.BindingModels;
using RouteGuideContracts.SearchModels;
using RouteGuideContracts.StoragesContracts;
using RouteGuideContracts.ViewModels;
using RouteGuideDatabaseImplement.Models;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace RouteGuideDatabaseImplement.Implements
{
///
/// Хранилище для сущности "Расписание"
///
public class ScheduleStorage : IScheduleStorage
{
///
/// Получение полного списка
///
///
public List GetFullList()
{
using var context = new RouteGuideDatabase();
return context.Schedules
.Include(x => x.Route)
.Select(x => x.GetViewModel)
.ToList();
}
///
/// Получение фильтрованного списка
///
///
///
public List GetFilteredList(ScheduleSearchModel model)
{
if (model.Id == null)
{
return new();
}
using var context = new RouteGuideDatabase();
return context.Schedules
.Include(x => x.Route)
.Where(x => x.Id.Equals(model.Id))
.Select(x => x.GetViewModel)
.ToList();
}
///
/// Получить список из заданного количества элементов
///
///
///
public List GetList(int count)
{
if (count <= 0)
{
return new();
}
using var context = new RouteGuideDatabase();
return context.Schedules
.Include(x => x.Route)
.Take(count)
.Select(x => x.GetViewModel)
.ToList();
}
///
/// Получение элемента
///
///
///
public ScheduleViewModel? GetElement(ScheduleSearchModel model)
{
if (model.Id == null)
{
return null;
}
using var context = new RouteGuideDatabase();
return context.Schedules
.Include(x => x.Route)
.FirstOrDefault(x => (model.Id != null && x.Id.Equals(model.Id)))
?.GetViewModel;
}
///
/// Добавление элемента
///
///
///
public ScheduleViewModel? Insert(ScheduleBindingModel model)
{
using var context = new RouteGuideDatabase();
var newSchedule = Schedule.Create(context, model);
if (newSchedule == null)
{
return null;
}
context.Schedules.Add(newSchedule);
context.SaveChanges();
return newSchedule.GetViewModel;
}
///
/// Редактирование элемента
///
///
///
public ScheduleViewModel? Update(ScheduleBindingModel model)
{
using var context = new RouteGuideDatabase();
var schedule = context.Schedules.FirstOrDefault(x => x.Id.Equals(model.Id));
if (schedule == null)
{
return null;
}
schedule.Update(model);
context.SaveChanges();
return schedule.GetViewModel;
}
///
/// Удаление элемента
///
///
///
public ScheduleViewModel? Delete(ScheduleBindingModel model)
{
using var context = new RouteGuideDatabase();
var schedule = context.Schedules.FirstOrDefault(x => x.Id.Equals(model.Id));
if (schedule == null)
{
return null;
}
context.Schedules.Remove(schedule);
context.SaveChanges();
return schedule.GetViewModel;
}
///
/// Удаление записи
///
///
public ScheduleViewModel? Delete()
{
using var context = new RouteGuideDatabase();
if (!context.Schedules.Any())
{
return null;
}
var element = context.Schedules.First();
context.Schedules.Remove(element);
context.SaveChanges();
return element.GetViewModel;
}
///
/// Удаление всех элементов
///
///
public int Clear()
{
using var context = new RouteGuideDatabase();
int count = context.Schedules.Count();
if (count <= 0)
{
return 0;
}
context.Schedules.RemoveRange(context.Schedules);
context.SaveChanges();
return count;
}
}
}