using ConfectioneryBusinessLogic.BusinessLogics;
using ConfectioneryContracts.BindingModels;
using ConfectioneryContracts.BusinessLogicsContracts;
using ConfectioneryDataModels.Enums;
using Microsoft.Extensions.Logging;
using System.Windows.Forms;

namespace ConfectioneryView
{
	public partial class FormMain : Form
	{
		private readonly ILogger _logger;
		private readonly IOrderLogic _orderLogic;
		private readonly IReportLogic _reportLogic;
		private readonly IWorkProcess _workProcess;

		public FormMain(ILogger<FormMain> logger, IOrderLogic orderLogic, IReportLogic reportLogic, IWorkProcess workProcess)
		{
			InitializeComponent();
			_logger = logger;
			_orderLogic = orderLogic;
			_reportLogic = reportLogic;
			_workProcess = workProcess;
		}
		private void FormMain_Load(object sender, EventArgs e)
		{
			LoadData();
		}
		private void LoadData()
		{
			try
			{
				var list = _orderLogic.ReadList(null);
				if (list != null)
				{
					dataGridView.DataSource = list;
					dataGridView.Columns["Id"].HeaderText = "����� ������";
					dataGridView.Columns["PastryId"].Visible = false;
					dataGridView.Columns["ClientId"].Visible = false;
					dataGridView.Columns["ImplementerId"].Visible = false;
					dataGridView.Columns["PastryName"].AutoSizeMode = DataGridViewAutoSizeColumnMode.Fill;
					dataGridView.Columns["ClientFIO"].AutoSizeMode = DataGridViewAutoSizeColumnMode.Fill;
					dataGridView.Columns["ImplementerFIO"].AutoSizeMode = DataGridViewAutoSizeColumnMode.Fill;
				}
				_logger.LogInformation("�������� �������");
			}
			catch (Exception ex)
			{
				_logger.LogError(ex, "������ �������� �������");
				MessageBox.Show(ex.Message, "������", MessageBoxButtons.OK,
				MessageBoxIcon.Error);
			}
		}
		private void ComponentsToolStripMenuItem_Click(object sender, EventArgs
		e)
		{
			var service = Program.ServiceProvider?.GetService(typeof(FormComponents));
			if (service is FormComponents form)
			{
				form.ShowDialog();
			}
		}
		private void PastryToolStripMenuItem_Click(object sender, EventArgs e)
		{
			var service = Program.ServiceProvider?.GetService(typeof(FormViewPastry));
			if (service is FormViewPastry form)
			{
				form.ShowDialog();
			}
		}

		private void ButtonCreateOrder_Click(object sender, EventArgs e)
		{
			var service =
			Program.ServiceProvider?.GetService(typeof(FormCreateOrder));
			if (service is FormCreateOrder form)
			{
				form.ShowDialog();
				LoadData();
			}
		}

		private void ButtonTakeOrderInWork_Click(object sender, EventArgs e)
		{
			if (dataGridView.SelectedRows.Count == 1)
			{
				int id = Convert.ToInt32(dataGridView.SelectedRows[0].Cells["Id"].Value);
				_logger.LogInformation("����� No{id}. �������� ������ �� '� ������'", id);
				try
				{
					var operationResult = _orderLogic.TakeOrderInWork(new OrderBindingModel { Id = id });
					if (!operationResult)
					{
						throw new Exception("������ ��� ����������. �������������� ���������� � �����.");
					}
					LoadData();
				}
				catch (Exception ex)
				{
					_logger.LogError(ex, "������ �������� ������ � ������");
					MessageBox.Show(ex.Message, "������", MessageBoxButtons.OK,
					MessageBoxIcon.Error);
				}
			}
		}
		private void ButtonOrderReady_Click(object sender, EventArgs e)
		{
			if (dataGridView.SelectedRows.Count == 1)
			{
				int id = Convert.ToInt32(dataGridView.SelectedRows[0].Cells["Id"].Value);
				OrderStatus orderStatus = (OrderStatus)dataGridView.SelectedRows[0].Cells["Status"].Value;
				_logger.LogInformation("����� No{id}. �������� ������ �� '�����'", id);
				try
				{
					var operationResult = _orderLogic.FinishOrder(new OrderBindingModel
					{
						Id = id,
						Status = orderStatus
					});
					if (!operationResult)
					{
						throw new Exception("������ ��� ����������. �������������� ���������� � �����.");
					}
					LoadData();
				}
				catch (Exception ex)
				{
					_logger.LogError(ex, "������ ������� � ���������� ������");
					MessageBox.Show(ex.Message, "������", MessageBoxButtons.OK, MessageBoxIcon.Error);
				}
			}
		}
		private void ButtonIssuedOrder_Click(object sender, EventArgs e)
		{
			if (dataGridView.SelectedRows.Count == 1)
			{
				int id =
				Convert.ToInt32(dataGridView.SelectedRows[0].Cells["Id"].Value);
				_logger.LogInformation("����� No{id}. �������� ������ �� '�����'", id);
				try
				{
					var operationResult = _orderLogic.DeliveryOrder(new
					OrderBindingModel
					{ Id = id });
					if (!operationResult)
					{
						throw new Exception("������ ��� ����������.�������������� ���������� � �����.");
					}
					_logger.LogInformation("����� No{id} �����", id);
					LoadData();
				}
				catch (Exception ex)
				{
					_logger.LogError(ex, "������ ������� � ������ ������");
					MessageBox.Show(ex.Message, "������", MessageBoxButtons.OK,
					MessageBoxIcon.Error);
				}
			}
		}
		private void ButtonRef_Click(object sender, EventArgs e)
		{
			LoadData();
		}

		private void PastriesToolStripMenuItem_Click_1(object sender, EventArgs e)
		{
			using var dialog = new SaveFileDialog { Filter = "docx|*.docx" };
			if (dialog.ShowDialog() == DialogResult.OK)
			{
				_reportLogic.SavePastriesToWordFile(new ReportBindingModel { FileName = dialog.FileName });
				MessageBox.Show("���������", "�����", MessageBoxButtons.OK, MessageBoxIcon.Information);
			}
		}

		private void PastryComponentsToolStripMenuItem_Click(object sender, EventArgs e)
		{
			var service = Program.ServiceProvider?.GetService(typeof(FormReportPastryComponents));
			if (service is FormReportPastryComponents form)
			{
				form.ShowDialog();
			}
		}

		private void OrdersToolStripMenuItem_Click(object sender, EventArgs e)
		{
			var service = Program.ServiceProvider?.GetService(typeof(FormReportOrders));
			if (service is FormReportOrders form)
			{
				form.ShowDialog();
			}
		}

		private void ClientsToolStripMenuItem_Click(object sender, EventArgs e)
		{
			var service = Program.ServiceProvider?.GetService(typeof(FormViewClients));
			if (service is FormViewClients form)
			{
				form.ShowDialog();
			}
		}

		private void ImplementersToolStripMenuItem_Click(object sender, EventArgs e)
		{
			var service = Program.ServiceProvider?.GetService(typeof(FormViewImplementers));
			if (service is FormViewImplementers form)
			{
				form.ShowDialog();
			}
		}

		private void DoWorkToolStripMenuItem_Click(object sender, EventArgs e)
		{
			_workProcess.DoWork((
				Program.ServiceProvider?.GetService(typeof(IImplementerLogic)) as IImplementerLogic)!,
				_orderLogic);
			MessageBox.Show("������� ��������� �������", "���������",
			MessageBoxButtons.OK, MessageBoxIcon.Information);
		}

		private void MailToolStripMenuItem_Click(object sender, EventArgs e)
		{
			var service = Program.ServiceProvider?.GetService(typeof(FormViewMail));
			if (service is FormViewMail form)
			{
				form.ShowDialog();
			}
		}
	}
}