using Microsoft.Extensions.Logging; using ProjectMonorail.CollectionGenericObjects; using ProjectMonorail.Drawings; using ProjectMonorail.Exceptions; using System.Windows.Forms; namespace ProjectMonorail; /// /// Форма работы с компанией и её коллекцией /// public partial class FormTrainCollection : Form { /// /// Хранилище коллекций /// private readonly StorageCollection _storageCollection; /// /// Компания /// private AbstractCompany? _company = null; /// /// Логер /// private readonly ILogger _logger; /// /// Конструктор /// public FormTrainCollection(ILogger logger) { InitializeComponent(); _storageCollection = new(); _logger = logger; } /// /// Выбор компании /// /// /// private void ComboBoxSelectorCompany_SelectedIndexChanged(object sender, EventArgs e) { panelCompanyTools.Enabled = false; } /// /// Добавление поезда /// /// /// private void ButtonAddTrain_Click(object sender, EventArgs e) { FormTrainConfig form = new(); form.AddEvent(SetTrain); form.Show(); } /// /// Добавление поезда в коллекцию /// /// private void SetTrain(DrawingTrain train) { if (_company == null || train == null) { return; } try { var set = _company + train; MessageBox.Show("Объект добавлен"); _logger.LogInformation($"Добавлен объект: {train.GetDataForSave()}"); pictureBox.Image = _company.Show(); } catch (CollectionOverflowException ex) { MessageBox.Show("Коллекция переполнена"); _logger.LogWarning($"Не удалось добавить объект в коллекцию: {ex.Message}"); } } /// /// Удаление объекта /// /// /// private void ButtonRemoveTrain_Click(object sender, EventArgs e) { if (string.IsNullOrEmpty(maskedTextBoxPosition.Text) || _company == null) { _logger.LogWarning("Удаление объекта из несуществующей коллекции"); return; } if (MessageBox.Show("Удалить объект?", "Удаление", MessageBoxButtons.YesNo, MessageBoxIcon.Question) == DialogResult.No) { return; } try { int pos = Convert.ToInt32(maskedTextBoxPosition.Text); if (_company - pos != null) { MessageBox.Show("Объект удален"); pictureBox.Image = _company.Show(); _logger.LogInformation("Удаление объекта по индексу {pos}", pos); } else { MessageBox.Show("Не удалось удалить объект"); _logger.LogInformation("Не удалось удалить объект из коллекции по индексу {pos}", pos); } } catch (ObjectNotFoundException ex) { MessageBox.Show("Ошибка: отсутствует объект"); _logger.LogError("Ошибка: {Message}", ex.Message); } catch (PositionOutOfCollectionException ex) { MessageBox.Show("Ошибка: неправильная позиция"); _logger.LogError("Ошибка: {Message}", ex.Message); } } /// /// Передача объекта в другую форму /// /// /// private void ButtonGoToCheck_Click(object sender, EventArgs e) { if (_company == null) { return; } DrawingTrain? train = null; int counter = 100; while (train == null) { try { train = _company.GetRandomObject(); } catch (ObjectNotFoundException) { counter--; if (counter <= 0) { break; } } } if (train == null) { return; } FormMonorail form = new() { SetTrain = train }; form.ShowDialog(); } /// /// Перерисовка коллекции /// /// /// 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.LogWarning("Создание компании без данных"); return; } CollectionType collectionType = CollectionType.None; if (radioButtonMassive.Checked) { collectionType = CollectionType.Massive; } if (radioButtonList.Checked) { collectionType = CollectionType.List; } _storageCollection.AddCollection(textBoxCollectionName.Text, collectionType); _logger.LogInformation($"Добавлена коллекция {textBoxCollectionName.Text}"); RefreshListBoxItems(); } /// /// Удаление коллекции /// /// /// private void ButtonCollectionDel_Click(object sender, EventArgs e) { if (listBoxCollection.SelectedIndex < 0 || listBoxCollection.SelectedItem == null) { MessageBox.Show("Коллекция не выбрана"); _logger.LogWarning("Удаление компании, не выбрав коллекцию"); return; } string name = listBoxCollection.SelectedItem.ToString() ?? string.Empty; if (MessageBox.Show("Удалить коллекцию?", "Удаление", MessageBoxButtons.YesNo, MessageBoxIcon.Question) == DialogResult.No) { return; } _storageCollection.DelCollection(listBoxCollection.SelectedItem.ToString()); _logger.LogInformation($"Удалена коллекция {name}"); RefreshListBoxItems(); } /// /// Обновление списка в 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("Коллекция не выбрана"); _logger.LogWarning("Создание компании, не выбрав коллекцию"); return; } CollectionGenericObject.ICollectionGenericObjects? collection = _storageCollection[listBoxCollection.SelectedItem.ToString() ?? string.Empty]; if (collection == null) { MessageBox.Show("Коллекция не проинициализирована"); _logger.LogWarning("Не далось иницализировать коллекцию"); return; } switch (comboBoxSelectorCompany.Text) { case "Хранилище": _company = new TrainSharingService(pictureBox.Width, pictureBox.Height, collection); _logger.LogInformation("Компания создана"); 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); _logger.LogInformation("Загрузка из файла: {filename}", saveFileDialog.FileName); RefreshListBoxItems(); } catch (Exception ex) { MessageBox.Show(ex.Message, "Результат", MessageBoxButtons.OK, MessageBoxIcon.Error); _logger.LogError("Ошибка: {Message}", ex.Message); } } } }