using System; using System.Collections.Generic; using System.Linq; using Dinah.Core; namespace DataLayer { public class AudibleSeriesId { public string Id { get; } public AudibleSeriesId(string id) { ArgumentValidator.EnsureNotNullOrWhiteSpace(id, nameof(id)); Id = id; } } public class Series { internal int SeriesId { get; private set; } public string AudibleSeriesId { get; private set; } /// optional public string Name { get; private set; } private HashSet _booksLink; public IEnumerable BooksLink => _booksLink? .OrderBy(sb => sb.Index) .ToList(); private Series() { } /// special id class b/c it's too easy to get string order mixed up public Series(AudibleSeriesId audibleSeriesId, string name = null) { ArgumentValidator.EnsureNotNull(audibleSeriesId, nameof(audibleSeriesId)); var id = audibleSeriesId.Id; ArgumentValidator.EnsureNotNullOrWhiteSpace(id, nameof(id)); AudibleSeriesId = id; _booksLink = new HashSet(); UpdateName(name); } public void UpdateName(string name) { // don't overwrite with null or whitespace but not an error if (!string.IsNullOrWhiteSpace(name)) Name = name; } public override string ToString() => Name; } }