94 lines
3.5 KiB
C#
94 lines
3.5 KiB
C#
|
using Microsoft.Extensions.Logging;
|
|||
|
using MotorPlantContracts.BindingModels;
|
|||
|
using MotorPlantContracts.BusinessLogicsContracts;
|
|||
|
using System;
|
|||
|
using System.Collections.Generic;
|
|||
|
using System.ComponentModel;
|
|||
|
using System.Data;
|
|||
|
using System.Drawing;
|
|||
|
using System.Linq;
|
|||
|
using System.Text;
|
|||
|
using System.Threading.Tasks;
|
|||
|
using System.Windows.Forms;
|
|||
|
|
|||
|
namespace MotorPlantView.Forms
|
|||
|
{
|
|||
|
public partial class FormReportEngineComponents : Form
|
|||
|
{
|
|||
|
private readonly ILogger _logger;
|
|||
|
private readonly IReportLogic _logic;
|
|||
|
public FormReportEngineComponents(ILogger<FormReportEngineComponents> logger, IReportLogic logic)
|
|||
|
{
|
|||
|
InitializeComponent();
|
|||
|
_logger = logger;
|
|||
|
_logic = logic;
|
|||
|
}
|
|||
|
private void FormReportEngineComponents_Load(object sender, EventArgs e)
|
|||
|
{
|
|||
|
try
|
|||
|
{
|
|||
|
var dict = _logic.GetEngineComponents();
|
|||
|
if (dict != null)
|
|||
|
{
|
|||
|
dataGridView.Rows.Clear();
|
|||
|
foreach (var elem in dict)
|
|||
|
{
|
|||
|
dataGridView.Rows.Add(new object[]
|
|||
|
{
|
|||
|
elem.EngineName,
|
|||
|
"",
|
|||
|
""
|
|||
|
});
|
|||
|
foreach (var listElem in elem.Components)
|
|||
|
{
|
|||
|
dataGridView.Rows.Add(new object[]
|
|||
|
{
|
|||
|
"",
|
|||
|
listElem.Item1,
|
|||
|
listElem.Item2,
|
|||
|
});
|
|||
|
}
|
|||
|
dataGridView.Rows.Add(new object[]
|
|||
|
{
|
|||
|
"Итого:",
|
|||
|
"",
|
|||
|
elem.TotalCount
|
|||
|
});
|
|||
|
dataGridView.Rows.Add(Array.Empty<object>());
|
|||
|
}
|
|||
|
}
|
|||
|
_logger.LogInformation("Загрузка списка изделий по компонентам");
|
|||
|
}
|
|||
|
catch (Exception ex)
|
|||
|
{
|
|||
|
_logger.LogError(ex, "Ошибка загрузки списка изделий по компонентам");
|
|||
|
MessageBox.Show(ex.Message, "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error);
|
|||
|
}
|
|||
|
}
|
|||
|
private void ButtonSaveToExcel_Click(object sender, EventArgs e)
|
|||
|
{
|
|||
|
using var dialog = new SaveFileDialog
|
|||
|
{
|
|||
|
Filter = "xlsx|*.xlsx"
|
|||
|
};
|
|||
|
if (dialog.ShowDialog() == DialogResult.OK)
|
|||
|
{
|
|||
|
try
|
|||
|
{
|
|||
|
_logic.SaveEngineComponentToExcelFile(new ReportBindingModel
|
|||
|
{
|
|||
|
FileName = dialog.FileName,
|
|||
|
});
|
|||
|
_logger.LogInformation("Сохранение списка изделий по компонентам");
|
|||
|
MessageBox.Show("Выполнено", "Успех", MessageBoxButtons.OK, MessageBoxIcon.Information);
|
|||
|
}
|
|||
|
catch (Exception ex)
|
|||
|
{
|
|||
|
_logger.LogError(ex, "Ошибка сохранения списка изделий по компонентам");
|
|||
|
MessageBox.Show(ex.Message, "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|