using ApplicationServices; using Avalonia; using Avalonia.Controls; using Avalonia.Input; using Avalonia.Markup.Xaml; using Avalonia.Threading; using DataLayer; using LibationWinForms.AvaloniaUI.ViewModels; using System; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Linq; using System.Threading.Tasks; namespace LibationWinForms.AvaloniaUI.Views { public partial class ProcessQueueControl2 : UserControl { private readonly ProcessQueueViewModel _viewModel; private ItemsRepeater _repeater; private ScrollViewer _scroller; private int _selectedIndex; private Random _random = new Random(0); private TrackedQueue2 Queue => _viewModel.Items; private readonly ProcessQueue.LogMe Logger; public ProcessQueueControl2() { InitializeComponent(); _repeater = this.Get("repeater"); _scroller = this.Get("scroller"); _repeater.PointerPressed += RepeaterClick; _repeater.KeyDown += RepeaterOnKeyDown; DataContext = _viewModel = new ProcessQueueViewModel(); Logger = ProcessQueue.LogMe.RegisterForm(_viewModel); ProcessBookControl2.PositionButtonClicked += ProcessBookControl2_ButtonClicked; ProcessBookControl2.CancelButtonClicked += ProcessBookControl2_CancelButtonClicked; #region Design Mode Testing if (Design.IsDesignMode) { using var context = DbContexts.GetContext(); var book = context.GetLibraryBook_Flat_NoTracking("B017V4IM1G"); List testList = new() { new ProcessBook2(book, Logger) { Result = ProcessBookResult.FailedAbort, Status = ProcessBookStatus.Failed, }, new ProcessBook2(book, Logger) { Result = ProcessBookResult.FailedSkip, Status = ProcessBookStatus.Failed, }, new ProcessBook2(book, Logger) { Result = ProcessBookResult.FailedRetry, Status = ProcessBookStatus.Failed, }, new ProcessBook2(book, Logger) { Result = ProcessBookResult.ValidationFail, Status = ProcessBookStatus.Failed, }, new ProcessBook2(book, Logger) { Result = ProcessBookResult.Cancelled, Status = ProcessBookStatus.Cancelled, }, new ProcessBook2(book, Logger) { Result = ProcessBookResult.Success, Status = ProcessBookStatus.Completed, }, new ProcessBook2(book, Logger) { Result = ProcessBookResult.None, Status = ProcessBookStatus.Working, }, new ProcessBook2(book, Logger) { Result = ProcessBookResult.None, Status = ProcessBookStatus.Queued, }, }; _viewModel.Items.Enqueue(testList); return; } #endregion } private void InitializeComponent() { AvaloniaXamlLoader.Load(this); } private bool isBookInQueue(LibraryBook libraryBook) => Queue.Any(b => b?.LibraryBook?.Book?.AudibleProductId == libraryBook.Book.AudibleProductId); public void AddDownloadPdf(LibraryBook libraryBook) => AddDownloadPdf(new List() { libraryBook }); public void AddDownloadDecrypt(LibraryBook libraryBook) => AddDownloadDecrypt(new List() { libraryBook }); public void AddConvertMp3(LibraryBook libraryBook) => AddConvertMp3(new List() { libraryBook }); public void AddDownloadPdf(IEnumerable entries) { List procs = new(); foreach (var entry in entries) { if (isBookInQueue(entry)) continue; ProcessBook2 pbook = new(entry, Logger); pbook.AddDownloadPdf(); procs.Add(pbook); } Serilog.Log.Logger.Information("Queueing {count} books", procs.Count); _viewModel.AddToQueue(procs); } public void AddDownloadDecrypt(IEnumerable entries) { List procs = new(); foreach (var entry in entries) { if (isBookInQueue(entry)) continue; ProcessBook2 pbook = new(entry, Logger); pbook.AddDownloadDecryptBook(); pbook.AddDownloadPdf(); procs.Add(pbook); } Serilog.Log.Logger.Information("Queueing {count} books", procs.Count); _viewModel.AddToQueue(procs); } public void AddConvertMp3(IEnumerable entries) { List procs = new(); foreach (var entry in entries) { if (isBookInQueue(entry)) continue; ProcessBook2 pbook = new(entry, Logger); pbook.AddConvertToMp3(); procs.Add(pbook); } Serilog.Log.Logger.Information("Queueing {count} books", procs.Count); _viewModel.AddToQueue(procs); } #region Control event handlers private async void ProcessBookControl2_CancelButtonClicked(ProcessBook2 item) { if (item is not null) await item.CancelAsync(); Queue.RemoveQueued(item); } private void ProcessBookControl2_ButtonClicked(ProcessBook2 item, QueuePosition queueButton) { Queue.MoveQueuePosition(item, queueButton); } private void RepeaterClick(object sender, PointerPressedEventArgs e) { if ((e.Source as TextBlock)?.DataContext is ProcessBook2 item) { _viewModel.SelectedItem = item; _selectedIndex = _viewModel.Items.IndexOf(item); } } private void RepeaterOnKeyDown(object sender, KeyEventArgs e) { if (e.Key == Key.F5) { //_viewModel.ResetItems(); } } public async void CancelAllBtn_Click(object sender, Avalonia.Interactivity.RoutedEventArgs e) { Queue.ClearQueue(); if (Queue.Current is not null) await Queue.Current.CancelAsync(); } public void ClearFinishedBtn_Click(object sender, Avalonia.Interactivity.RoutedEventArgs e) { Queue.ClearCompleted(); if (!_viewModel.Running) _viewModel.RunningTime = string.Empty; } public void ClearLogBtn_Click(object sender, Avalonia.Interactivity.RoutedEventArgs e) { _viewModel.LogEntries.Clear(); } private void LogCopyBtn_Click(object sender, Avalonia.Interactivity.RoutedEventArgs e) { string logText = string.Join("\r\n", _viewModel.LogEntries.Select(r => $"{r.LogDate.ToShortDateString()} {r.LogDate.ToShortTimeString()}\t{r.LogMessage}")); System.Windows.Forms.Clipboard.SetDataObject(logText, false, 5, 150); } private async void cancelAllBtn_Click(object sender, EventArgs e) { Queue.ClearQueue(); if (Queue.Current is not null) await Queue.Current.CancelAsync(); } private void btnClearFinished_Click(object sender, EventArgs e) { Queue.ClearCompleted(); if (!_viewModel.Running) _viewModel.RunningTime = string.Empty; } #endregion } }