Crunchy-Downloader/CRD/Downloader/ProgramManager.cs
Elwador 5d94025fcc Add - Added encoding option to muxing settings
Add - Added Custom encoding presets
Add - Added Skip Muxing to muxing settings
Add - Added Dubs to file name settings
Add - IP check in settings to check if VPN is being used
Add - Dubs to "Add Downloads" Tab
Add - Series folder link to history series if it finds the folder
Add - Added command line arguments
Add - Added proxy settings to the Settings tab (changes require a restart to take effect)
Add - Added option to set "Sign" subs forced flag
Add - Added option to set "CC" subs "hearing-impaired" flag
Add - Added encoding presets editing
Add - Added CC subtitles font option to the settings
Add - Added available dubs to history episodes

Chg - Defaults to system accent color when no color is selected in the settings
Chg - Audio only mux to only copy and not encode
Chg - Update dialog
Chg - Light mode color adjustments
Chg - Http Connection change to detect proxy (Clash)
Chg - Settings filename description
Chg - Changed FPS on encoding presets to 24fps
Chg - Adjusted encoding to allow h264_nvenc & hevc_nvenc
Chg - Moved sync timing folders from the Windows temp folder to the application root's temp folder
Chg - The temp folder will now be deleted automatically when empty

Fix - Locale not correctly applied to Urls in the "Add Downloads" Tab
Fix - Locale not correctly applied to Search in the "Add Downloads" Tab
Fix - Scrolling issue in settings
Fix - Fix crash when removing streaming tokens (TOO_MANY_ACTIVE_STREAMS)
Fix - Search didn't reset correctly
Fix - Clash proxy didn't work
Fix - Chapters were always taken from the original version (mainly JP)
Fix - Connection issue
Fix - Fixed an issue where proxy settings were only available when history was enabled
Fix - Fixed scrolling issues with certain series in the "Add Downloads" tab
Fix - Fixed an issue where History Series appeared incomplete after being added then deleted and re-added
Fix - Fixed a crash related to sync timing
2024-09-30 20:08:37 +02:00

176 lines
No EOL
5.2 KiB
C#

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Threading.Tasks;
using Avalonia;
using Avalonia.Controls.ApplicationLifetimes;
using Avalonia.Media;
using Avalonia.Styling;
using CommunityToolkit.Mvvm.ComponentModel;
using CRD.Downloader.Crunchyroll;
using CRD.Utils.Updater;
using FluentAvalonia.Styling;
namespace CRD.Downloader;
public partial class ProgramManager : ObservableObject{
#region Singelton
private static ProgramManager? _instance;
private static readonly object Padlock = new();
public static ProgramManager Instance{
get{
if (_instance == null){
lock (Padlock){
if (_instance == null){
_instance = new ProgramManager();
}
}
}
return _instance;
}
}
#endregion
#region Observables
[ObservableProperty]
private bool _fetchingData;
[ObservableProperty]
private bool _updateAvailable = true;
[ObservableProperty]
private bool _finishedLoading = false;
#endregion
private readonly FluentAvaloniaTheme? _faTheme;
private Queue<Func<Task>> taskQueue = new Queue<Func<Task>>();
private bool exitOnTaskFinish = false;
public ProgramManager(){
_faTheme = Application.Current?.Styles[0] as FluentAvaloniaTheme;
foreach (var arg in Environment.GetCommandLineArgs()){
if (arg == "--historyRefreshAll"){
taskQueue.Enqueue(RefreshAll);
} else if (arg == "--historyAddToQueue"){
taskQueue.Enqueue(AddMissingToQueue);
} else if (arg == "--exit"){
exitOnTaskFinish = true;
}
}
Init();
CleanUpOldUpdater();
}
private async Task RefreshAll(){
FetchingData = true;
foreach (var item in CrunchyrollManager.Instance.HistoryList){
item.SetFetchingData();
}
for (int i = 0; i < CrunchyrollManager.Instance.HistoryList.Count; i++){
await CrunchyrollManager.Instance.HistoryList[i].FetchData("");
CrunchyrollManager.Instance.HistoryList[i].UpdateNewEpisodes();
}
FetchingData = false;
CrunchyrollManager.Instance.History.SortItems();
}
private async Task AddMissingToQueue(){
var tasks = CrunchyrollManager.Instance.HistoryList
.Select(item => item.AddNewMissingToDownloads());
await Task.WhenAll(tasks);
while (QueueManager.Instance.Queue.Any(e => e.DownloadProgress != null && e.DownloadProgress.Done != true)){
Console.WriteLine("Waiting for downloads to complete...");
await Task.Delay(2000); // Wait for 2 second before checking again
}
}
private async void Init(){
CrunchyrollManager.Instance.InitOptions();
UpdateAvailable = await Updater.Instance.CheckForUpdatesAsync();
if (CrunchyrollManager.Instance.CrunOptions.AccentColor != null && !string.IsNullOrEmpty(CrunchyrollManager.Instance.CrunOptions.AccentColor)){
if (_faTheme != null) _faTheme.CustomAccentColor = Color.Parse(CrunchyrollManager.Instance.CrunOptions.AccentColor);
}
if (_faTheme != null && Application.Current != null){
if (CrunchyrollManager.Instance.CrunOptions.Theme == "System"){
_faTheme.PreferSystemTheme = true;
} else if (CrunchyrollManager.Instance.CrunOptions.Theme == "Dark"){
_faTheme.PreferSystemTheme = false;
Application.Current.RequestedThemeVariant = ThemeVariant.Dark;
} else{
_faTheme.PreferSystemTheme = false;
Application.Current.RequestedThemeVariant = ThemeVariant.Light;
}
}
await CrunchyrollManager.Instance.Init();
FinishedLoading = true;
await WorkOffArgsTasks();
}
private async Task WorkOffArgsTasks(){
if (taskQueue.Count == 0){
return;
}
while (taskQueue.Count > 0){
var task = taskQueue.Dequeue();
await task(); // Execute the task asynchronously
}
Console.WriteLine("All tasks are completed.");
if (exitOnTaskFinish){
Console.WriteLine("Exiting...");
IClassicDesktopStyleApplicationLifetime? lifetime = (IClassicDesktopStyleApplicationLifetime)Application.Current?.ApplicationLifetime;
if (lifetime != null){
lifetime.Shutdown();
} else{
Environment.Exit(0);
}
}
}
private void CleanUpOldUpdater(){
string backupFilePath = Path.Combine(Directory.GetCurrentDirectory(), "Updater.exe.bak");
if (File.Exists(backupFilePath)){
try{
File.Delete(backupFilePath);
Console.WriteLine($"Deleted old updater file: {backupFilePath}");
} catch (Exception ex){
Console.Error.WriteLine($"Failed to delete old updater file: {ex.Message}");
}
} else{
Console.WriteLine("No old updater file found to delete.");
}
}
}