using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using UniversityContracts.BindingModels;
using UniversityContracts.SearchModels;
using UniversityContracts.StorageContracts;
using UniversityContracts.ViewModels;
using UniversityDatabaseImplement.Models;
using UniversityDataModels.Enums;

namespace UniversityDatabaseImplement.Implements
{
    public class UserStorage : IUserStorage
    {
        public List<UserViewModel> GetFullList()
        {
            using var context = new UniversityDatabase();
            return context.Users.Select(x => x.GetViewModel).ToList();
        }
        public List<UserViewModel> GetFilteredList(UserSearchModel model)
        {
            if (model.Role == null || model.Role == UserRole.Неизвестная)
            {
                return new();
            }
            using var context = new UniversityDatabase();
            return context.Users.Where(x => x.Role == model.Role).Select(x => x.GetViewModel).ToList();
        }
        public UserViewModel? GetElement(UserSearchModel model)
        {
            if (string.IsNullOrEmpty(model.Login) && string.IsNullOrEmpty(model.Password))
            {
                return null;
            }
            using var context = new UniversityDatabase();

            //Поиск пользователя при входе в систему по логину, паролю и его роли (чтобы не могли войти в аккаунты другой роли)
            // UPD По роли не ищется
            if (!string.IsNullOrEmpty(model.Login) && !string.IsNullOrEmpty(model.Password) && model.Role.HasValue)
            {

				return context.Users.FirstOrDefault(x => x.Login == model.Login && x.Password == model.Password)?.GetViewModel;
            }
            //Получение по логину (пользователей с таким логином будет 1 или 0)
            if (!string.IsNullOrEmpty(model.Login))
            {
                return context.Users.FirstOrDefault(x => x.Login == model.Login)?.GetViewModel;
            }
            //Получение по почте (пользователей с такой почтой будет 1 или 0)
            else if (!string.IsNullOrEmpty(model.Email))
            {
                return context.Users.FirstOrDefault(x => x.Email == model.Email)?.GetViewModel;
            }
            //Получение по id
            return context.Users.FirstOrDefault(x => x.Id == model.Id)?.GetViewModel;
        }

        public UserViewModel? Insert(UserBindingModel model)
        {
            var newUser = User.Create(model);
            if (newUser == null)
            {
                return null;
            }
            using var context = new UniversityDatabase();
            context.Users.Add(newUser);
            context.SaveChanges();
            return newUser.GetViewModel;
        }

        public UserViewModel? Update(UserBindingModel model)
        {
            using var context = new UniversityDatabase();
            var user = context.Users.FirstOrDefault(x => x.Id == model.Id);
            if (user == null)
            {
                return null;
            }
            user.Update(model);
            context.SaveChanges();
            return user.GetViewModel;
        }
        public UserViewModel? Delete(UserBindingModel model)
        {
            using var context = new UniversityDatabase();
            var user = context.Users.FirstOrDefault(rec => rec.Id == model.Id);
            if (user != null)
            {
                context.Users.Remove(user);
                context.SaveChanges();
                return user.GetViewModel;
            }
            return null;
        }
    }
}