mirror of
https://github.com/Crunchy-DL/Crunchy-Downloader.git
synced 2026-04-22 09:21:57 +00:00
Add - Added background image option to the Appearance settings Add - Background Image Settings - Added new options to control opacity and blur radius Add - Added "Couldn't sync dubs" status if the syncing failed Add - Added functionality to combine multiple episodes from the same season into a single entry in the calendar Add - Added video resolution display next to dubs/subs in the downloads tab Add - Added Cloudflare check to image loading Add - Added hardsub selection if the current is not available Add - Added part size setting to configure the size of parts downloaded at the same time Add - Added quality override to history series Add - Added history marker to search results to indicate if a series is already in the user's history Add - Added seasons tab for seasonal releases (Spring, Summer, Fall, Winter) Add - Added potential releases and release times for the current day and the next week to the custom calendar Chg - Changed Calendar cards background color for improved visibility Chg - Combined Appearance settings into a single section in the settings tab Chg - Consolidated Debug settings into one settings expander for better organization Chg - Changed time sync to now check both the start and end of the video Chg - Changed encoding progress to be displayed by the progress bar Chg - Updated the functionality for hiding dubs in the custom calendar Chg - Adjusted Dub sync to improve accuracy, resolving issues where it failed for more episodes than expected Chg - Subtitles and dubs are now sorted according to the order selected in the MKV file Chg - Changed logout behavior to correctly log out if login fails when starting the downloader Chg - Changed that all downloaded files are removed if an in-progress download is removed from the queue Chg - Changed default profile image Chg - Updated used packages to the newest version Chg - Separated settings to separate tabs Fix - Fixed some series didn't get added to the history Fix - Fixed an issue with file path length that prevented some files from being accessed properly Fix - Fixed an issue where file names exceeded the maximum allowable length, causing errors Fix - Fixed an issue where refreshing a series could get stuck Fix - Fixed a crash that could happen with the syncing Fix - Fixed an issue where the download status showed "Done" while moving files from the temp folder Fix - Fixed an issue where cookies were not being utilized correctly Fix - Resolved issues with displaying dates in UTC format Fix - Fixed an issue with incorrect calendar grouping Fix - Fixed an issue with the previous week navigation in the calendar Fix - Fixed an issue where the calendar would not display correctly when not logged in Fix - Fixed incorrect FFmpeg check for other OS (Linux/macOS) Fix - Fixed an issue where image loading used a different HTTP client
190 lines
No EOL
5.8 KiB
C#
190 lines
No EOL
5.8 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Collections.ObjectModel;
|
|
using System.IO;
|
|
using System.Linq;
|
|
using System.Threading.Tasks;
|
|
using Avalonia;
|
|
using Avalonia.Controls.ApplicationLifetimes;
|
|
using Avalonia.Media;
|
|
using Avalonia.Platform.Storage;
|
|
using Avalonia.Styling;
|
|
using CommunityToolkit.Mvvm.ComponentModel;
|
|
using CRD.Downloader.Crunchyroll;
|
|
using CRD.Utils;
|
|
using CRD.Utils.Structs;
|
|
using CRD.Utils.Structs.History;
|
|
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
|
|
|
|
|
|
public Dictionary<string, List<AnilistSeries>> AnilistSeasons = new();
|
|
public Dictionary<string, List<CalendarEpisode>> AnilistUpcoming = new();
|
|
|
|
private readonly FluentAvaloniaTheme? _faTheme;
|
|
|
|
private Queue<Func<Task>> taskQueue = new Queue<Func<Task>>();
|
|
|
|
private bool exitOnTaskFinish = false;
|
|
|
|
public IStorageProvider StorageProvider;
|
|
|
|
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;
|
|
}
|
|
}
|
|
|
|
if (!string.IsNullOrEmpty(CrunchyrollManager.Instance.CrunOptions.BackgroundImagePath)){
|
|
Helpers.SetBackgroundImage(CrunchyrollManager.Instance.CrunOptions.BackgroundImagePath, CrunchyrollManager.Instance.CrunOptions.BackgroundImageOpacity,
|
|
CrunchyrollManager.Instance.CrunOptions.BackgroundImageBlurRadius);
|
|
}
|
|
|
|
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.");
|
|
}
|
|
}
|
|
} |