79 lines
2.9 KiB
C#

using FuelAccounting.Entities;
using FuelAccounting.Repositories;
namespace FuelAccounting.Forms
{
public partial class FormEquipage : Form
{
private readonly IEquipageRepository _equipageRepository;
public FormEquipage(IEquipageRepository equipageRepository,
ICarsRepository carsRepository, IDriversRepository driversRepository,
IRouteRepository routeRepository, IShiftRepository shiftRepository)
{
InitializeComponent();
_equipageRepository = equipageRepository ??
throw new ArgumentNullException(nameof(equipageRepository));
comboBoxCar.DataSource = carsRepository.ReadCars();
comboBoxCar.DisplayMember = "Model";
comboBoxCar.ValueMember = "Id";
comboBoxDriver.DataSource = driversRepository.ReadDrivers();
comboBoxDriver.DisplayMember = "FirstName";
comboBoxDriver.ValueMember = "Id";
comboBoxShift.DataSource = shiftRepository.ReadShifts();
comboBoxShift.DisplayMember = "Description";
comboBoxShift.ValueMember = "Id";
ColumnRoute.DataSource = routeRepository.ReadRoutes();
ColumnRoute.DisplayMember = "Description";
ColumnRoute.ValueMember = "Id";
}
private void ButtonSave_Click(object sender, EventArgs e)
{
try
{
if (dataGridViewRoutes.RowCount < 1 ||
comboBoxCar.SelectedIndex < 0 ||
comboBoxDriver.SelectedIndex < 0 ||
comboBoxShift.SelectedIndex < 0)
{
throw new Exception("Имеются незаполненные поля");
}
_equipageRepository.CreateEquipage(Equipage.CreateOperation(0,
(int)comboBoxCar.SelectedValue!, (int)comboBoxDriver.SelectedValue!,
(int)comboBoxShift.SelectedValue!, CreateListRoutesEquipageFromDataGrid()));
Close();
}
catch (Exception ex)
{
MessageBox.Show(ex.Message, "Ошибка при сохранении", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
}
private void ButtonCancel_Click(object sender, EventArgs e) => Close();
private List<RoutesEqipage> CreateListRoutesEquipageFromDataGrid()
{
var list = new List<RoutesEqipage>();
foreach (DataGridViewRow row in dataGridViewRoutes.Rows)
{
if (row.Cells["ColumnRoute"].Value == null || row.Cells["ColumnCount"].Value == null)
{
continue;
}
list.Add(RoutesEqipage.CreateElement(0, Convert.ToInt32(row.Cells["ColumnRoute"].Value),
Convert.ToInt32(row.Cells["ColumnCount"].Value)));
}
return list;
}
}
}