|
|
|
@ -60,8 +60,6 @@ namespace MediaBrowser.Controller.Entities
|
|
|
|
|
|
|
|
|
|
protected BaseItem()
|
|
|
|
|
{
|
|
|
|
|
ThemeSongIds = Array.Empty<Guid>();
|
|
|
|
|
ThemeVideoIds = Array.Empty<Guid>();
|
|
|
|
|
Tags = Array.Empty<string>();
|
|
|
|
|
Genres = Array.Empty<string>();
|
|
|
|
|
Studios = Array.Empty<string>();
|
|
|
|
@ -100,12 +98,52 @@ namespace MediaBrowser.Controller.Entities
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
[JsonIgnore]
|
|
|
|
|
public Guid[] ThemeSongIds { get; set; }
|
|
|
|
|
public Guid[] ThemeSongIds
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
if (_themeSongIds == null)
|
|
|
|
|
{
|
|
|
|
|
_themeSongIds = GetExtras()
|
|
|
|
|
.Where(extra => extra.ExtraType == Model.Entities.ExtraType.ThemeSong)
|
|
|
|
|
.Select(song => song.Id)
|
|
|
|
|
.ToArray();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return _themeSongIds;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private set
|
|
|
|
|
{
|
|
|
|
|
_themeSongIds = value;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[JsonIgnore]
|
|
|
|
|
public Guid[] ThemeVideoIds { get; set; }
|
|
|
|
|
public Guid[] ThemeVideoIds
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
if (_themeVideoIds == null)
|
|
|
|
|
{
|
|
|
|
|
_themeVideoIds = GetExtras()
|
|
|
|
|
.Where(extra => extra.ExtraType == Model.Entities.ExtraType.ThemeVideo)
|
|
|
|
|
.Select(song => song.Id)
|
|
|
|
|
.ToArray();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return _themeVideoIds;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private set
|
|
|
|
|
{
|
|
|
|
|
_themeVideoIds = value;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[JsonIgnore]
|
|
|
|
|
public string PreferredMetadataCountryCode { get; set; }
|
|
|
|
|
|
|
|
|
|
[JsonIgnore]
|
|
|
|
|
public string PreferredMetadataLanguage { get; set; }
|
|
|
|
|
|
|
|
|
@ -635,6 +673,9 @@ namespace MediaBrowser.Controller.Entities
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private string _sortName;
|
|
|
|
|
private Guid[] _themeSongIds;
|
|
|
|
|
private Guid[] _themeVideoIds;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets the name of the sort.
|
|
|
|
|
/// </summary>
|
|
|
|
@ -1582,7 +1623,8 @@ namespace MediaBrowser.Controller.Entities
|
|
|
|
|
|
|
|
|
|
await Task.WhenAll(tasks).ConfigureAwait(false);
|
|
|
|
|
|
|
|
|
|
item.ThemeVideoIds = newThemeVideoIds;
|
|
|
|
|
// They are expected to be sorted by SortName
|
|
|
|
|
item.ThemeVideoIds = newThemeVideos.OrderBy(i => i.SortName).Select(i => i.Id).ToArray();
|
|
|
|
|
|
|
|
|
|
return themeVideosChanged;
|
|
|
|
|
}
|
|
|
|
@ -1619,7 +1661,8 @@ namespace MediaBrowser.Controller.Entities
|
|
|
|
|
|
|
|
|
|
await Task.WhenAll(tasks).ConfigureAwait(false);
|
|
|
|
|
|
|
|
|
|
item.ThemeSongIds = newThemeSongIds;
|
|
|
|
|
// They are expected to be sorted by SortName
|
|
|
|
|
item.ThemeSongIds = newThemeSongs.OrderBy(i => i.SortName).Select(i => i.Id).ToArray();
|
|
|
|
|
|
|
|
|
|
return themeSongsChanged;
|
|
|
|
|
}
|
|
|
|
@ -2910,12 +2953,12 @@ namespace MediaBrowser.Controller.Entities
|
|
|
|
|
|
|
|
|
|
public IEnumerable<BaseItem> GetThemeSongs()
|
|
|
|
|
{
|
|
|
|
|
return ThemeVideoIds.Select(LibraryManager.GetItemById).Where(i => i.ExtraType.Equals(Model.Entities.ExtraType.ThemeSong)).OrderBy(i => i.SortName);
|
|
|
|
|
return ThemeSongIds.Select(LibraryManager.GetItemById);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public IEnumerable<BaseItem> GetThemeVideos()
|
|
|
|
|
{
|
|
|
|
|
return ThemeVideoIds.Select(LibraryManager.GetItemById).Where(i => i.ExtraType.Equals(Model.Entities.ExtraType.ThemeVideo)).OrderBy(i => i.SortName);
|
|
|
|
|
return ThemeVideoIds.Select(LibraryManager.GetItemById);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|