using Microsoft.Extensions.Logging; using ProjectAirplaneWithRadar.CollectionGenericObjects; using ProjectAirplaneWithRadar.Drawnings; using ProjectAirplaneWithRadar.Exceptions; namespace ProjectAirplaneWithRadar { /// /// Форма работы с компанией и ее коллекцией /// public partial class FormAirplaneCollection : Form { /// /// Хранилише коллекций /// private readonly StorageCollection _storageCollection; /// /// Компания /// private AbstractCompany? _company = null; /// /// Логер /// private readonly ILogger _logger; /// /// Конструктор /// public FormAirplaneCollection(ILogger logger) { InitializeComponent(); _storageCollection = new(); _logger = logger; _logger.LogInformation("Форма загрузилась"); } /// /// Выбор компании /// /// /// private void ComboBoxSelectorCompany_SelectedIndexChanged(object sender, EventArgs e) { panelCompanyTools.Enabled = false; } /// /// Добавление самолета /// /// /// private void ButtonAddAirplane_Click(object sender, EventArgs e) { FormAirplaneConfig form = new(); form.Show(); form.AddEvent(SetAirplane); } /// /// Добавление самолета в коллекцию /// /// private void SetAirplane(DrawningAirplane airplane) { try { if (_company == null || airplane == null) { return; } if (_company + airplane != -1) { MessageBox.Show("Объект добавлен"); pictureBox.Image = _company.Show(); _logger.LogInformation("Добавлен объект: {0}", airplane.GetDataForSave()); } } catch (CollectionOverflowException ex) { MessageBox.Show(ex.Message); _logger.LogError("Ошибка: {Message}", ex.Message); } } /// /// Удаление объекта /// /// /// private void ButtonRemoveAirplane_Click(object sender, EventArgs e) { if (string.IsNullOrEmpty(maskedTextBoxPosition.Text) || _company == null) { return; } if (MessageBox.Show("Удалить объект?", "Удаление", MessageBoxButtons.YesNo, MessageBoxIcon.Question) != DialogResult.Yes) { return; } try { int pos = Convert.ToInt32(maskedTextBoxPosition.Text); if (_company - pos != null) { MessageBox.Show("Объект удален"); pictureBox.Image = _company.Show(); _logger.LogInformation("Удалён объект по позиции {0}", pos); } } catch (PositionOutOfCollectionException ex) { MessageBox.Show(ex.Message); _logger.LogError("Ошибка: {Message}", ex.Message); } catch (ObjectNotFoundException ex) { MessageBox.Show(ex.Message); _logger.LogError("Ошибка: {Message}", ex.Message); } } /// /// Передача объекта в другую форму /// /// /// private void buttonGoToCheck_Click(object sender, EventArgs e) { if (_company == null) { return; } try { DrawningAirplane? plane = null; int counter = 100; while (plane == null) { plane = _company.GetRandomObject(); counter--; if (counter <= 0) { break; } } if (plane == null) { return; } FormAirplaneWithRadar form = new() { SetAirplane = plane }; form.ShowDialog(); } catch (ObjectNotFoundException) { _logger.LogError("Ошибка при передаче объекта на FormAirplaneWithRadar"); } } /// /// Перерисовка коллекции /// /// /// private void ButtonRefresh_Click(object sender, EventArgs e) { if (_company == null) { return; } pictureBox.Image = _company.Show(); } /// /// Добавление коллекции /// /// /// private void ButtonCollectionAdd_Click(object sender, EventArgs e) { if (string.IsNullOrEmpty(textBoxCollectionName.Text) || (!radioButtonList.Checked && !radioButtonMassive.Checked)) { MessageBox.Show("Не все данные заполнены", "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error); _logger.LogError("Ошибка: Заполнены не все данные для добавления коллекции"); return; } CollectionType collectionType = CollectionType.None; if (radioButtonMassive.Checked) collectionType = CollectionType.Massive; else if (radioButtonList.Checked) collectionType = CollectionType.List; _storageCollection.AddCollection(textBoxCollectionName.Text, collectionType); RefreshListBoxItems(); _logger.LogInformation("Добавлена коллекция: {Collection} типа: {Type}", textBoxCollectionName.Text, collectionType); } /// /// Удаление коллекции /// /// /// private void ButtonCollectionDel_Click(object sender, EventArgs e) { if (listBoxCollection.SelectedItems == null || listBoxCollection.SelectedIndex < 0) { MessageBox.Show("Коллекция не выбрана"); return; } if (MessageBox.Show("Удалить коллекцию?", "Удаление", MessageBoxButtons.YesNo, MessageBoxIcon.Question) == DialogResult.No) { return; } _storageCollection.DelCollection(listBoxCollection.SelectedItem.ToString()); RefreshListBoxItems(); _logger.LogInformation("Коллекция удалена: {0}", textBoxCollectionName.Text); } /// /// Обновление списка в listBoxCollection /// private void RefreshListBoxItems() { listBoxCollection.Items.Clear(); for (int i = 0; i < _storageCollection.Keys?.Count; ++i) { string? colName = _storageCollection.Keys?[i]; if (!string.IsNullOrEmpty(colName)) listBoxCollection.Items.Add(colName); } } /// /// Создание компании /// /// /// private void ButtonCreateCompany_Click(object sender, EventArgs e) { if (listBoxCollection.SelectedIndex < 0 || listBoxCollection.SelectedItem == null) { MessageBox.Show("Коллекция не выбрана"); return; } ICollectionGenericObjects? collection = _storageCollection[listBoxCollection.SelectedItem.ToString() ?? string.Empty]; if (collection == null) { MessageBox.Show("Коллекция не проинициализирована"); return; } switch (comboBoxSelectorCompany.Text) { case "Хранилище": _company = new PlaneSharingService(pictureBox.Width, pictureBox.Height, collection); _logger.LogInformation("Создна компания типа {Company}, коллекция: {Collection}", comboBoxSelectorCompany.Text, textBoxCollectionName.Text); _logger.LogInformation("Создана компания на коллекции: {Collection}", textBoxCollectionName.Text); break; } panelCompanyTools.Enabled = true; RefreshListBoxItems(); } /// /// Обработка нажатия "Сохранение" /// /// /// private void SaveToolStripMenuItem_Click(object sender, EventArgs e) { if (saveFileDialog.ShowDialog() == DialogResult.OK) { try { _storageCollection.SaveData(saveFileDialog.FileName); MessageBox.Show("Сохранение прошло успешно", "Результат", MessageBoxButtons.OK, MessageBoxIcon.Information); _logger.LogInformation("Сохранение в файл: {filename}", saveFileDialog.FileName); } catch (Exception ex) { MessageBox.Show(ex.Message, "Результат", MessageBoxButtons.OK, MessageBoxIcon.Error); _logger.LogError("Ошибка: {Message}", ex.Message); } } } /// /// Обработка нажатия "Загрузка" /// /// /// private void LoadToolStripMenuItem_Click(object sender, EventArgs e) { if (openFileDialog.ShowDialog() == DialogResult.OK) { try { _storageCollection.LoadData(openFileDialog.FileName); MessageBox.Show("Загрузка прошла успешно", "Результат", MessageBoxButtons.OK, MessageBoxIcon.Information); RefreshListBoxItems(); _logger.LogInformation("Загрузка из файла: {filename}", saveFileDialog.FileName); } catch (Exception ex) { MessageBox.Show($"Не загрузилось: {ex.Message}", "Результат", MessageBoxButtons.OK, MessageBoxIcon.Error); _logger.LogError("Ошибка: {Message}", ex.Message); } } } } }