mirror of
https://github.com/Kareadita/Kavita.git
synced 2025-06-23 15:30:34 -04:00
* Refactored invite user flow to separate error handling on create user flow and email flow. This should help users that have unique situations. * Switch to using files to check LastWriteTime. Debug code in for Robbie to test on rclone * Updated Parser namespace. Changed the LastWriteTime to check all files and folders.
77 lines
2.5 KiB
C#
77 lines
2.5 KiB
C#
using System;
|
|
using System.Collections.Concurrent;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using API.Data;
|
|
using API.Entities;
|
|
|
|
namespace API.Helpers;
|
|
|
|
public static class GenreHelper
|
|
{
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
/// <param name="allGenres"></param>
|
|
/// <param name="names"></param>
|
|
/// <param name="isExternal"></param>
|
|
/// <param name="action"></param>
|
|
public static void UpdateGenre(ICollection<Genre> allGenres, IEnumerable<string> names, bool isExternal, Action<Genre> action)
|
|
{
|
|
foreach (var name in names)
|
|
{
|
|
if (string.IsNullOrEmpty(name.Trim())) continue;
|
|
|
|
var normalizedName = Services.Tasks.Scanner.Parser.Parser.Normalize(name);
|
|
var genre = allGenres.FirstOrDefault(p =>
|
|
p.NormalizedTitle.Equals(normalizedName) && p.ExternalTag == isExternal);
|
|
if (genre == null)
|
|
{
|
|
genre = DbFactory.Genre(name, false);
|
|
allGenres.Add(genre);
|
|
}
|
|
|
|
action(genre);
|
|
}
|
|
}
|
|
|
|
|
|
public static void KeepOnlySameGenreBetweenLists(ICollection<Genre> existingGenres, ICollection<Genre> removeAllExcept, Action<Genre> action = null)
|
|
{
|
|
var existing = existingGenres.ToList();
|
|
foreach (var genre in existing)
|
|
{
|
|
var existingPerson = removeAllExcept.FirstOrDefault(g => g.ExternalTag == genre.ExternalTag && genre.NormalizedTitle.Equals(g.NormalizedTitle));
|
|
if (existingPerson != null) continue;
|
|
existingGenres.Remove(genre);
|
|
action?.Invoke(genre);
|
|
}
|
|
|
|
}
|
|
|
|
/// <summary>
|
|
/// Adds the genre to the list if it's not already in there. This will ignore the ExternalTag.
|
|
/// </summary>
|
|
/// <param name="metadataGenres"></param>
|
|
/// <param name="genre"></param>
|
|
public static void AddGenreIfNotExists(ICollection<Genre> metadataGenres, Genre genre)
|
|
{
|
|
var existingGenre = metadataGenres.FirstOrDefault(p =>
|
|
p.NormalizedTitle == Services.Tasks.Scanner.Parser.Parser.Normalize(genre.Title));
|
|
if (existingGenre == null)
|
|
{
|
|
metadataGenres.Add(genre);
|
|
}
|
|
}
|
|
|
|
public static void AddGenreIfNotExists(BlockingCollection<Genre> metadataGenres, Genre genre)
|
|
{
|
|
var existingGenre = metadataGenres.FirstOrDefault(p =>
|
|
p.NormalizedTitle == Services.Tasks.Scanner.Parser.Parser.Normalize(genre.Title));
|
|
if (existingGenre == null)
|
|
{
|
|
metadataGenres.Add(genre);
|
|
}
|
|
}
|
|
}
|