// Copyright (c) 2025 - schick Informatik // Description: Display control of formsheet Tab 9. Pas data departure // using bsmd.database; using ENI2.EditControls; using ENI2.Locode; using ENI2.Util; using ExcelDataReader; using Microsoft.Win32; using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Windows; using System.Windows.Controls; using System.Windows.Media.Imaging; namespace ENI2.SheetDisplayControls { /// /// Interaction logic for PassengerDepartureControl.xaml /// public partial class PassengerDepartureControl : DetailBaseControl { #region Fields private Message _pasMessage; private Message _pasdMessage; #endregion #region Construction public PassengerDepartureControl() { InitializeComponent(); } #endregion #region public override public override void Initialize() { base.Initialize(); foreach (Message aMessage in this.Messages) { if (aMessage.MessageNotificationClass == Message.NotificationClass.PASA) { this._pasMessage = aMessage; this.ControlMessages.Add(aMessage); } if (aMessage.MessageNotificationClass == Message.NotificationClass.PASD) { this._pasdMessage = aMessage; this.ControlMessages.Add(aMessage); } } #region init PASD if (this._pasdMessage == null) { this._pasdMessage = this.Core.CreateMessage(Message.NotificationClass.PASD); this.Messages.Add(this._pasdMessage); } this.dataGridPassengerListDeparture.Initialize(); this.dataGridPassengerListDeparture.ItemsSource = this._pasdMessage.Elements; this.dataGridPassengerListDeparture.AddingNewItem += DataGridPassengerListDeparture_AddingNewItem; this.dataGridPassengerListDeparture.EditRequested += DataGridPassengerListDeparture_EditRequested; this.dataGridPassengerListDeparture.DeleteRequested += DataGridPassengerListDeparture_DeleteRequested; this.dataGridPassengerListDeparture.CreateRequested += DataGridPassengerListDeparture_CreateRequested; this.dataGridPassengerListDeparture.RefreshGrid += DataGridPassengerListDeparture_RefreshGrid; this.dataGridPassengerListDeparture.MultiEditRequested += DataGridPassengerListDeparture_MultiEditRequested; if (this._pasdMessage.Elements.Count > 0) { this.checkBoxPasNotificationSchengenDeparture.IsChecked = ((PASD)this._pasdMessage.Elements[0]).NotificationSchengen; this.checkBoxPasNotificationPAXDeparture.IsChecked = ((PASD)this._pasdMessage.Elements[0]).NotificationPAX; } // extra menu copy to PASA { this.dataGridPassengerListDeparture.ContextMenu.Items.Add(new Separator()); MenuItem copyPASDItem = new MenuItem(); copyPASDItem.Header = Properties.Resources.textCopyToPASA; copyPASDItem.Icon = new Image { Source = new BitmapImage(new Uri("pack://application:,,,/Resources/documents.png")) }; copyPASDItem.Click += CopyPASDItem_Click; this.dataGridPassengerListDeparture.ContextMenu.Items.Add(copyPASDItem); } #endregion } #endregion #region event handler private void CopyPASDItem_Click(object sender, RoutedEventArgs e) { if (this.dataGridPassengerListDeparture.SelectedItems != null) { foreach (PASD pasd in this.dataGridPassengerListDeparture.SelectedItems) { PAS pasa = new PAS(); pasa.MessageHeader = this._pasMessage; pasa.CopyFromPAS(pasd); pasa.IsDeparture = false; pasa.Identifier = DatabaseEntity.GetNewIdentifier(this._pasMessage.Elements); this._pasMessage.Elements.Add(pasa); this.SublistElementChanged(Message.NotificationClass.PASA); } } } private void checkBoxPasNotificationSchengenDeparture_Click(object sender, RoutedEventArgs e) { foreach (PASD pasd in _pasdMessage.Elements.Cast()) { pasd.NotificationSchengen = checkBoxPasNotificationSchengenDeparture.IsChecked; } this.SublistElementChanged(Message.NotificationClass.PASD); } private void checkBoxPasNotificationPAXDeparture_Click(object sender, RoutedEventArgs e) { foreach (PASD pasd in _pasdMessage.Elements.Cast()) { pasd.NotificationPAX = checkBoxPasNotificationPAXDeparture.IsChecked; } this.SublistElementChanged(Message.NotificationClass.PASD); } private void buttonImportExcelPassengerDeparture_Click(object sender, RoutedEventArgs e) { OpenFileDialog ofd = new OpenFileDialog { Filter = "Excel Files|*.xls;*.xlsx" }; if (ofd.ShowDialog() ?? false) { FileStream stream; try { stream = File.Open(ofd.FileName, FileMode.Open, FileAccess.Read); } catch (Exception ex) { MessageBox.Show(ex.Message, "Error", MessageBoxButton.OK, MessageBoxImage.Error); return; } using (var reader = ExcelReaderFactory.CreateReader(stream)) { List importPassenger = new List(); try { do { while (reader.Read()) { if (((IExcelDataReader)reader).FieldCount < 17) { throw new InvalidDataException("Sheet must have 17 columns of data"); } PASD pas = new PASD(); if (reader.IsDBNull(0) && reader.IsDBNull(1)) continue; if (!reader.IsDBNull(0)) pas.PassengerLastName = reader.GetValue(0).ToString(); if (pas.PassengerLastName.Equals("Family Name") || (pas.PassengerLastName.Trim().Length == 0)) continue; if (!reader.IsDBNull(1)) pas.PassengerFirstName = reader.GetValue(1).ToString(); if (!reader.IsDBNull(2)) pas.PassengerGender = GlobalStructures.ParseGender(reader.GetString(2)); if (!reader.IsDBNull(3)) pas.PassengerPortOfEmbarkation = reader.GetString(3); if (LocodeDB.PortNameFromLocode(pas.PassengerPortOfEmbarkation) == null) pas.PassengerPortOfEmbarkation = null; if (!reader.IsDBNull(4)) pas.PassengerPortOfDisembarkation = reader.GetString(4); if (LocodeDB.PortNameFromLocode(pas.PassengerPortOfDisembarkation) == null) pas.PassengerPortOfDisembarkation = null; if (!reader.IsDBNull(5)) pas.PassengerInTransit = GlobalStructures.ReadBoolean(reader.GetString(5)); if (!reader.IsDBNull(6)) pas.PassengerNationality = reader.GetString(6).Substring(0, 2).ToUpper(); if (!reader.IsDBNull(7)) pas.PassengerPlaceOfBirth = reader.GetString(7); if (!reader.IsDBNull(8)) pas.PassengerCountryOfBirth = reader.GetString(8).Substring(0, 2).ToUpper(); if (!reader.IsDBNull(9)) pas.PassengerDateOfBirth = reader.GetDateTime(9); if (!reader.IsDBNull(10)) pas.PassengerIdentityDocumentType = GlobalStructures.ReadIdentityDocumentType(reader.GetString(10)); if (!reader.IsDBNull(11)) pas.PassengerIdentityDocumentId = reader.ReadAsString( 11); if (!reader.IsDBNull(12)) pas.PassengerIdentityDocumentIssuingState = reader.GetString(12).Substring(0, 2).ToUpper(); if (!reader.IsDBNull(13)) pas.PassengerIdentityDocumentExpiryDate = reader.GetDateTime(13); if (!reader.IsDBNull(14)) pas.PassengerVisaNumber = reader.ReadAsString(14); if (!reader.IsDBNull(15)) pas.EmergencyCare = reader.GetString(15); if (!reader.IsDBNull(16)) pas.EmergencyContactNumber = reader.ReadAsString(16); pas.MessageHeader = this._pasMessage; pas.IsDirty = true; pas.Identifier = PASD.GetNewIdentifier(this._pasdMessage.Elements); this._pasdMessage.Elements.Add(pas); importPassenger.Add(pas); } } while (reader.NextResult()); } catch (Exception ex) { MessageBox.Show("Error reading Excel: " + ex.Message, Properties.Resources.textCaptionError, MessageBoxButton.OK, MessageBoxImage.Error); } if (importPassenger.Count > 0) { this.dataGridPassengerListDeparture.Items.Refresh(); this.SublistElementChanged(Message.NotificationClass.PASD); MessageBox.Show(String.Format(Properties.Resources.textPassengerImported, importPassenger.Count), Properties.Resources.textCaptionInformation, MessageBoxButton.OK, MessageBoxImage.Information); } } stream.Close(); } } private async void buttonDeleteAllPasD_Click(object sender, RoutedEventArgs e) { if (MessageBox.Show(Properties.Resources.textConfimDeleteAllEntries, Properties.Resources.textConfirmation, MessageBoxButton.YesNo, MessageBoxImage.Question, MessageBoxResult.No) == MessageBoxResult.Yes) { foreach (PASD pasd in this._pasdMessage.Elements.Cast()) { await DBManagerAsync.DeleteAsync(pasd); } this._pasdMessage.Elements.Clear(); this.dataGridPassengerListDeparture.Items.Refresh(); this.SublistElementChanged(Message.NotificationClass.PASD); } } #endregion #region passenger grid departure private void DataGridPassengerListDeparture_CreateRequested() { EditPASDialog epd = new EditPASDialog { PAS = new PASD() }; epd.PAS.IsDeparture = true; epd.PAS.Identifier = PASD.GetNewIdentifier(_pasdMessage.Elements); epd.PAS.MessageHeader = this._pasdMessage; epd.AddClicked += () => { epd.CopyValuesToEntity(); if (!this._pasdMessage.Elements.Contains(epd.PAS)) { this._pasdMessage.Elements.Add(epd.PAS); this.CheckPASD(); } this.dataGridPassengerListDeparture.Items.Refresh(); epd.PAS = new PASD { IsDeparture = true, MessageHeader = this._pasdMessage, Identifier = PASD.GetNewIdentifier(_pasdMessage.Elements) }; this.SublistElementChanged(Message.NotificationClass.PASD); }; if (epd.ShowDialog() ?? false) { if (!this._pasdMessage.Elements.Contains(epd.PAS)) { _pasdMessage.Elements.Add(epd.PAS); this.CheckPASD(); } this.dataGridPassengerListDeparture.Items.Refresh(); this.SublistElementChanged(Message.NotificationClass.PASD); } } private void DataGridPassengerListDeparture_DeleteRequested(DatabaseEntity obj) { if (obj is PASD pasd) { // are you sure dialog is in base class _pasdMessage.Elements.Remove(pasd); DBManager.Instance.Delete(pasd); } } private void DataGridPassengerListDeparture_RefreshGrid() { DatabaseEntity.ResetIdentifiers(_pasdMessage.Elements); this.SublistElementChanged(Message.NotificationClass.PASD); this.dataGridPassengerListDeparture.Items.Refresh(); } private void DataGridPassengerListDeparture_EditRequested(DatabaseEntity obj) { EditPASDialog epd = new EditPASDialog { PAS = obj as PASD }; epd.AddClicked += () => { epd.CopyValuesToEntity(); if (!_pasMessage.Elements.Contains(epd.PAS)) { _pasMessage.Elements.Add(epd.PAS); this.CheckPASD(); } this.dataGridPassengerListDeparture.Items.Refresh(); epd.PAS = new PASD { IsDeparture = true, Identifier = PASD.GetNewIdentifier(_pasdMessage.Elements), MessageHeader = _pasdMessage }; this.SublistElementChanged(Message.NotificationClass.PASD); }; if (epd.ShowDialog() ?? false) { if (!_pasdMessage.Elements.Contains(epd.PAS)) { _pasdMessage.Elements.Add(epd.PAS); this.CheckPASD(); } epd.PAS.IsDirty = true; this.dataGridPassengerListDeparture.Items.Refresh(); this.SublistElementChanged(Message.NotificationClass.PASD); } } private void DataGridPassengerListDeparture_AddingNewItem(object sender, AddingNewItemEventArgs e) { this.DataGridPassengerListDeparture_CreateRequested(); } private void DataGridPassengerListDeparture_MultiEditRequested(List databaseEntities) { List pasList = new List(); foreach (PAS apas in databaseEntities.Cast()) pasList.Add(apas); // write common values of all PAS entities to template entity PAS pas = PAS.CreateCommon(pasList); EditPASDialog dialog = new EditPASDialog(); dialog.PAS = pas; dialog.AddVisible = false; if (dialog.ShowDialog() ?? false) { // write back changed values from pas to all entities and mark them as changed PAS.WriteTemplateToList(pas, pasList); this.SublistElementChanged(Message.NotificationClass.PASD); this.dataGridPassengerListDeparture.Items.Refresh(); } } #endregion #region private methods private void CheckPASD() { if (this._pasdMessage.Elements.Count == 0) return; PASD firstPAS = this._pasdMessage.Elements[0] as PASD; if (this._pasdMessage.Elements.Count == 1) { firstPAS.NotificationSchengen = true; this.checkBoxPasNotificationSchengenDeparture.IsChecked = true; } else { for (int i = 1; i < this._pasdMessage.Elements.Count; i++) { ((PASD)this._pasdMessage.Elements[i]).NotificationSchengen = firstPAS.NotificationSchengen; } } } #endregion } }