Crunchy-Downloader/CRD/Utils/Parser/Utils/ObjectUtilities.cs
Elwador 95cd06a523 Add - Added path reset buttons to Temp Folder Path, Download Folder, and Background Image settings
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
2024-12-19 19:01:50 +01:00

109 lines
No EOL
4.2 KiB
C#

using System;
using System.Collections.Generic;
using System.Dynamic;
namespace CRD.Utils.Parser.Utils;
public class ObjectUtilities{
public static ExpandoObject MergeExpandoObjects(dynamic target, dynamic source){
var result = new ExpandoObject();
var resultDict = result as IDictionary<string, object>;
// Cast source and target to dictionaries if they are not null
var targetDict = target as IDictionary<string, object>;
var sourceDict = source as IDictionary<string, object>;
// If both are null, return an empty ExpandoObject
if (targetDict == null && sourceDict == null){
Console.WriteLine("Nothing Merged; both are empty");
return result; // result is already a new ExpandoObject
}
// Copy targetDict into resultDict
if (targetDict != null){
foreach (var kvp in targetDict){
resultDict[kvp.Key] = kvp.Value; // Add or overwrite key-value pairs
}
}
// Copy sourceDict into resultDict, potentially overwriting values from targetDict
if (sourceDict != null){
foreach (var kvp in sourceDict){
resultDict[kvp.Key] = kvp.Value; // Overwrites if key exists
}
}
return result;
}
public static void SetAttributeWithDefault(dynamic ob, string attributeName, string defaultValue){
var obDict = ob as IDictionary<string, object>;
if (obDict == null){
throw new ArgumentException("Provided object must be an ExpandoObject.");
}
// Check if the attribute exists and is not null or empty
if (obDict.TryGetValue(attributeName, out object value) && value != null && !string.IsNullOrEmpty(value.ToString())){
obDict[attributeName] = value;
} else{
obDict[attributeName] = defaultValue;
}
}
public static object GetAttributeWithDefault(dynamic ob, string attributeName, string defaultValue){
var obDict = ob as IDictionary<string, object>;
if (obDict == null){
throw new ArgumentException("Provided object must be an ExpandoObject.");
}
// Check if the attribute exists and is not null or empty
if (obDict.TryGetValue(attributeName, out object value) && value != null && !string.IsNullOrEmpty(value.ToString())){
return value;
} else{
return defaultValue;
}
}
public static void SetFieldFromOrToDefault(dynamic targetObject, string fieldToSet, string fieldToGetValueFrom, object defaultValue){
var targetDict = targetObject as IDictionary<string, object>;
if (targetDict == null){
throw new ArgumentException("Provided targetObject must be an ExpandoObject.");
}
// Attempt to get the value from the specified field
object valueToSet = defaultValue;
if (targetDict.TryGetValue(fieldToGetValueFrom, out object valueFromField) && valueFromField != null){
valueToSet = valueFromField;
}
// Set the specified field to the retrieved value or the default value
targetDict[fieldToSet] = valueToSet;
}
public static object GetMemberValue(dynamic obj, string memberName){
// First, check if the object is indeed an ExpandoObject
if (obj is ExpandoObject expando){
// Try to get the value from the ExpandoObject
var dictionary = (IDictionary<string, object>)expando;
if (dictionary.TryGetValue(memberName, out object value)){
// Return the found value, which could be null
return value;
}
} else if (obj != null){
// For non-ExpandoObject dynamics, attempt to access the member directly
// This part might throw exceptions if the member does not exist
try{
return obj.GetType().GetProperty(memberName)?.GetValue(obj, null) ??
obj.GetType().GetField(memberName)?.GetValue(obj);
} catch{
// Member access failed, handle accordingly (e.g., log the issue)
}
}
// Member doesn't exist or obj is null, return null or a default value
return null;
}
}