using SecuritySystemClientApp.Models;
using SecuritySystemContracts.BindingModels;
using SecuritySystemContracts.ViewModels;
using Microsoft.AspNetCore.Mvc;
using System.Diagnostics;

namespace SecuritySystemClientApp.Controllers
{
    public class HomeController : Controller
    {
        private readonly ILogger<HomeController> _logger;

        public HomeController(ILogger<HomeController> logger)
        {
            _logger = logger;
        }

        //вытаскивает через API клиента Get-запросом список его собственных заказов
        public IActionResult Index()
        {
            if (APIClient.Client == null)
            {
                return Redirect("~/Home/Enter");
            }

            return View(APIClient.GetRequest<List<OrderViewModel>>($"api/main/getorders?clientId={APIClient.Client.Id}"));
        }

        //изменемение ланных Get-ом
        [HttpGet]
        public IActionResult Privacy()
        {
            if (APIClient.Client == null)
            {
                return Redirect("~/Home/Enter");
            }

            return View(APIClient.Client);
        }

        //изменение данных Post-ом
        [HttpPost]
        public void Privacy(string login, string password, string fio)
        {
            if (APIClient.Client == null)
            {
                throw new Exception("Вы как сюда попали? Суда вход только авторизованным");
            }

            if (string.IsNullOrEmpty(login) || string.IsNullOrEmpty(password) || string.IsNullOrEmpty(fio))
            {
                throw new Exception("Введите логин, пароль и ФИО");
            }

            APIClient.PostRequest("api/client/updatedata", new ClientBindingModel
            {
                Id = APIClient.Client.Id,
                ClientFIO = fio,
                Email = login,
                Password = password
            });

            APIClient.Client.ClientFIO = fio;
            APIClient.Client.Email = login;
            APIClient.Client.Password = password;

            Response.Redirect("Index");
        }

        [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
        public IActionResult Error()
        {
            return View(new ErrorViewModel
            {
                RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier
            });
        }

        //просто открытие вьюхи
        [HttpGet]
        public IActionResult Enter()
        {
            return View();
        }

        //отсылаем указанные данные на проверку
        [HttpPost]
        public void Enter(string login, string password)
        {
            if (string.IsNullOrEmpty(login) || string.IsNullOrEmpty(password))
            {
                throw new Exception("Введите логин и пароль");
            }

            APIClient.Client = APIClient.GetRequest<ClientViewModel>($"api/client/login?login={login}&password={password}");

            if (APIClient.Client == null)
            {
                throw new Exception("Неверный логин/пароль");
            }

            Response.Redirect("Index");
        }

        //просто открытие вьюхи
        [HttpGet]
        public IActionResult Register()
        {
            return View();
        }

        //Post-запрос по созданию нового пользователя
        [HttpPost]
        public void Register(string login, string password, string fio)
        {
            if (string.IsNullOrEmpty(login) || string.IsNullOrEmpty(password) || string.IsNullOrEmpty(fio))
            {
                throw new Exception("Введите логин, пароль и ФИО");
            }

            APIClient.PostRequest("api/client/register", new ClientBindingModel
            {
                ClientFIO = fio,
                Email = login,
                Password = password
            });

            //переход на вкладку "Enter", чтобы пользователь сразу смог зайти
            Response.Redirect("Enter");

            return;
        }

        //создание заказа. Получаем и передаём список изделий во вьюху?
        [HttpGet]
        public IActionResult Create()
        {
            ViewBag.Secures = APIClient.GetRequest<List<SecureViewModel>>("api/main/getsecurelist");

            return View();
        }

        //создание заказа Post-запросом
        [HttpPost]
        public void Create(int secure, int count)
        {
            if (APIClient.Client == null)
            {
                throw new Exception("Вы как сюда попали? Суда вход только авторизованным");
            }

            if (count <= 0)
            {
                throw new Exception("Количество и сумма должны быть больше 0");
            }

            APIClient.PostRequest("api/main/createorder", new OrderBindingModel
            {
                ClientId = APIClient.Client.Id,
                SecureId = secure,
                Count = count,
                Sum = Calc(count, secure)
            });

            Response.Redirect("Index");
        }

        //подсчёт стоимости заказа
        [HttpPost]
        public double Calc(int count, int secure)
        {
            var manuf = APIClient.GetRequest<SecureViewModel>($"api/main/getsecure?secureId={secure}"
            );

            return count * (manuf?.Price ?? 1);
        }

        //для работы с письмами
        [HttpGet]
        public IActionResult Mails()
        {
            if (APIClient.Client == null)
            {
                return Redirect("~/Home/Enter");
            }

            return View(APIClient.GetRequest<List<MessageInfoViewModel>>($"api/client/getmessages?clientId={APIClient.Client.Id}"));
        }
    }
}