From ce13e3aeb959bbe81a5a001756fdd735aa4a31e4 Mon Sep 17 00:00:00 2001 From: Kevin Cox <164852005+KJ-Cox@users.noreply.github.com> Date: Fri, 26 Apr 2024 01:54:48 +1000 Subject: [PATCH] Update for Trakt to use FanartHandler ClearArt paths for Movies (#1) * Update for Trakt to use FanartHandler ClearArt paths for Movies * Clear Movie imdb value for page navigation to avoid clearart from appearing on page navigation when options selected * Clear Trakt movie imdb on page nav * Added TV Series ClearArt and fixed issues * Updated to fix TVSeries and more * Bug fixes * Updated MovingPictures clearart paths * Updates --- FanartHandler/FanartHandler.cs | 29 +++++++++---- FanartHandler/FanartSelectedOther.cs | 52 ++++++++++++++++++++-- FanartHandler/Utils.cs | 64 ++++++++++++++++++++++++++-- FanartHandler/UtilsTVSeries.cs | 28 ++++++++++++ 4 files changed, 157 insertions(+), 16 deletions(-) diff --git a/FanartHandler/FanartHandler.cs b/FanartHandler/FanartHandler.cs index cdcae1d..3731f9b 100644 --- a/FanartHandler/FanartHandler.cs +++ b/FanartHandler/FanartHandler.cs @@ -810,6 +810,7 @@ internal void Start() Utils.Check(FSelected.WindowsUsingFanartSelectedPictures.Count > 0) + " Pictures Fanart, " + Utils.Check(FSelected.WindowsUsingFanartSelectedScoreCenter.Count > 0) + " ScoreCenter Fanart"); logger.Debug(" " + Utils.Check(FSelectedOther.WindowsUsingFanartSelectedClearArtMusic.Count > 0) + " Music ClearArt, " + + Utils.Check(FSelectedOther.WindowsUsingFanartSelectedClearArtMovie.Count > 0) + " Movie ClearArt, " + Utils.Check(FSelectedOther.WindowsUsingFanartSelectedGenreMusic.Count > 0) + " Music Genres, " + Utils.Check(FSelectedOther.WindowsUsingFanartSelectedLabelMusic.Count > 0) + " Music Labels"); logger.Debug(" " + Utils.Check(FSelectedOther.WindowsUsingFanartSelectedStudioMovie.Count > 0) + " Movie Studios, " + @@ -1643,6 +1644,7 @@ private void SetupWindowsUsingFanartHandlerVisibility(string SkinDir = (string) var _flagClearArt = false; var _flagClearArtPlay = false; + var _flagClearArtMovies = false; var _flagLabelMusic = false; var _flagLabelPlay = false; @@ -1666,7 +1668,7 @@ private void SetupWindowsUsingFanartHandlerVisibility(string SkinDir = (string) ref _flag1Movie, ref _flag2Movie, ref _flag1Picture, ref _flag2Picture, ref _flagPlay, - ref _flagClearArt, ref _flagClearArtPlay, + ref _flagClearArt, ref _flagClearArtPlay, ref _flagClearArtMovies, ref _flagGenrePlay, ref _flagGenrePlaySingle, ref _flagGenrePlayAll, ref _flagGenrePlayVertical, ref _flagGenreMusic, ref _flagGenreMusicSingle, ref _flagGenreMusicAll, ref _flagGenreMusicVertical, ref _flagGenreMovie, ref _flagGenreMovieSingle, ref _flagGenreMovieAll, ref _flagGenreMovieVertical, @@ -1690,7 +1692,7 @@ ref skinFile ref _flag1Movie, ref _flag2Movie, ref _flag1Picture, ref _flag2Picture, ref _flagPlay, - ref _flagClearArt, ref _flagClearArtPlay, + ref _flagClearArt, ref _flagClearArtPlay, ref _flagClearArtMovies, ref _flagGenrePlay, ref _flagGenrePlaySingle, ref _flagGenrePlayAll, ref _flagGenrePlayVertical, ref _flagGenreMusic, ref _flagGenreMusicSingle, ref _flagGenreMusicAll, ref _flagGenreMusicVertical, ref _flagGenreMovie, ref _flagGenreMovieSingle, ref _flagGenreMovieAll, ref _flagGenreMovieVertical, @@ -1709,7 +1711,7 @@ ref skinFile ref _flag1Movie, ref _flag2Movie, ref _flag1Picture, ref _flag2Picture, ref _flagPlay, - ref _flagClearArt, ref _flagClearArtPlay, + ref _flagClearArt, ref _flagClearArtPlay, ref _flagClearArtMovies, ref _flagGenrePlay, ref _flagGenrePlaySingle, ref _flagGenrePlayAll, ref _flagGenrePlayVertical, ref _flagGenreMusic, ref _flagGenreMusicSingle, ref _flagGenreMusicAll, ref _flagGenreMusicVertical, ref _flagGenreMovie, ref _flagGenreMovieSingle, ref _flagGenreMovieAll, ref _flagGenreMovieVertical, @@ -1730,7 +1732,7 @@ ref skinFile ref _flag1Movie, ref _flag2Movie, ref _flag1Picture, ref _flag2Picture, ref _flagPlay, - ref _flagClearArt, ref _flagClearArtPlay, + ref _flagClearArt, ref _flagClearArtPlay, ref _flagClearArtMovies, ref _flagGenrePlay, ref _flagGenrePlaySingle, ref _flagGenrePlayAll, ref _flagGenrePlayVertical, ref _flagGenreMusic, ref _flagGenreMusicSingle, ref _flagGenreMusicAll, ref _flagGenreMusicVertical, ref _flagGenreMovie, ref _flagGenreMovieSingle, ref _flagGenreMovieAll, ref _flagGenreMovieVertical, @@ -1759,7 +1761,7 @@ ref skinFile ref _flag1Movie, ref _flag2Movie, ref _flag1Picture, ref _flag2Picture, ref _flagPlay, - ref _flagClearArt, ref _flagClearArtPlay, + ref _flagClearArt, ref _flagClearArtPlay, ref _flagClearArtMovies, ref _flagGenrePlay, ref _flagGenrePlaySingle, ref _flagGenrePlayAll, ref _flagGenrePlayVertical, ref _flagGenreMusic, ref _flagGenreMusicSingle, ref _flagGenreMusicAll, ref _flagGenreMusicVertical, ref _flagGenreMovie, ref _flagGenreMovieSingle, ref _flagGenreMovieAll, ref _flagGenreMovieVertical, @@ -1778,7 +1780,7 @@ ref skinFile ref _flag1Movie, ref _flag2Movie, ref _flag1Picture, ref _flag2Picture, ref _flagPlay, - ref _flagClearArt, ref _flagClearArtPlay, + ref _flagClearArt, ref _flagClearArtPlay, ref _flagClearArtMovies, ref _flagGenrePlay, ref _flagGenrePlaySingle, ref _flagGenrePlayAll, ref _flagGenrePlayVertical, ref _flagGenreMusic, ref _flagGenreMusicSingle, ref _flagGenreMusicAll, ref _flagGenreMusicVertical, ref _flagGenreMovie, ref _flagGenreMovieSingle, ref _flagGenreMovieAll, ref _flagGenreMovieVertical, @@ -1799,7 +1801,7 @@ ref skinFile ref _flag1Movie, ref _flag2Movie, ref _flag1Picture, ref _flag2Picture, ref _flagPlay, - ref _flagClearArt, ref _flagClearArtPlay, + ref _flagClearArt, ref _flagClearArtPlay, ref _flagClearArtMovies, ref _flagGenrePlay, ref _flagGenrePlaySingle, ref _flagGenrePlayAll, ref _flagGenrePlayVertical, ref _flagGenreMusic, ref _flagGenreMusicSingle, ref _flagGenreMusicAll, ref _flagGenreMusicVertical, ref _flagGenreMovie, ref _flagGenreMovieSingle, ref _flagGenreMovieAll, ref _flagGenreMovieVertical, @@ -1848,6 +1850,11 @@ ref skinFile { FSelectedOther.WindowsUsingFanartSelectedClearArtMusic.Add(nodeValue, nodeValue); } + // Selected Movie ClearArt + if (_flagClearArtMovies && !Utils.ContainsID(FSelectedOther.WindowsUsingFanartSelectedClearArtMovie, nodeValue)) + { + FSelectedOther.WindowsUsingFanartSelectedClearArtMovie.Add(nodeValue, nodeValue); + } #endregion #region Labels @@ -2047,7 +2054,7 @@ private void HandleXmlImports(string filename, string windowId, ref bool _flag1Movie, ref bool _flag2Movie, ref bool _flag1Picture, ref bool _flag2Picture, ref bool _flagPlay, - ref bool _flagClearArt, ref bool _flagClearArtPlay, + ref bool _flagClearArt, ref bool _flagClearArtPlay, ref bool _flagClearArtMovies, ref bool _flagGenrePlay, ref bool _flagGenrePlaySingle, ref bool _flagGenrePlayAll, ref bool _flagGenrePlayVertical, ref bool _flagGenreMusic, ref bool _flagGenreMusicSingle, ref bool _flagGenreMusicAll, ref bool _flagGenreMusicVertical, ref bool _flagGenreMovie, ref bool _flagGenreMovieSingle, ref bool _flagGenreMovieAll, ref bool _flagGenreMovieVertical, @@ -2136,6 +2143,12 @@ private void HandleXmlImports(string filename, string windowId, _flagClearArt = true; } + // ClearArt Movies + if (_xml.Contains("#fanarthandler.movie.clearart.selected") || _xml.Contains("#fanarthandler.movie.clearlogo.selected") || _xml.Contains("#fanarthandler.movie.cd.selected") || _xml.Contains("#fanarthandler.series.clearart.selected") || _xml.Contains("#fanarthandler.series.clearlogo.selected")) + { + _flagClearArtMovies = true; + } + // Labels if (_xml.Contains("#fanarthandler.music.labels.selected")) { diff --git a/FanartHandler/FanartSelectedOther.cs b/FanartHandler/FanartSelectedOther.cs index c3bd9c5..11476aa 100644 --- a/FanartHandler/FanartSelectedOther.cs +++ b/FanartHandler/FanartSelectedOther.cs @@ -38,6 +38,7 @@ internal class FanartSelectedOther public int RefreshTickCount { get; set; } public Hashtable WindowsUsingFanartSelectedClearArtMusic { get; set; } + public Hashtable WindowsUsingFanartSelectedClearArtMovie { get; set; } public Hashtable WindowsUsingFanartSelectedGenreMusic { get; set; } public Hashtable WindowsUsingFanartSelectedLabelMusic { get; set; } @@ -62,6 +63,7 @@ public FanartSelectedOther() RefreshTickCount = 0; WindowsUsingFanartSelectedClearArtMusic = new Hashtable(); + WindowsUsingFanartSelectedClearArtMovie = new Hashtable(); WindowsUsingFanartSelectedGenreMusic = new Hashtable(); WindowsUsingFanartSelectedLabelMusic = new Hashtable(); @@ -97,6 +99,7 @@ public bool CheckValidWindowIDForFanart() Utils.ContainsID(WindowsUsingFanartSelectedGenreMovie) || Utils.ContainsID(WindowsUsingFanartSelectedStudioMovie) || Utils.ContainsID(WindowsUsingFanartSelectedClearArtMusic) || + Utils.ContainsID(WindowsUsingFanartSelectedClearArtMovie) || Utils.ContainsID(WindowsUsingFanartSelectedAwardMovie) ); } @@ -153,7 +156,7 @@ public void RefreshGenericSelectedProperties(Utils.SelectedType property, ref st if (isVideo) { - AddSelectedMoviePropertys(); + AddSelectedMoviePropertys(SelectedItem); } ResetRefreshTickCount(); @@ -301,7 +304,8 @@ public void RefreshSelected(RefreshWorker rw, System.ComponentModel.DoWorkEventA { if (Utils.ContainsID(WindowsUsingFanartSelectedGenreMovie) || Utils.ContainsID(WindowsUsingFanartSelectedStudioMovie) || - Utils.ContainsID(WindowsUsingFanartSelectedAwardMovie)) + Utils.ContainsID(WindowsUsingFanartSelectedAwardMovie) || + Utils.ContainsID(WindowsUsingFanartSelectedClearArtMovie)) { IsSelectedVideo = true; RefreshGenericSelectedProperties(Utils.SelectedType.Movie, @@ -838,7 +842,7 @@ public void AddSelectedGenreProperty(string Genres, string sTitle, Utils.Selecte FanartAvailable = FanartAvailable || picFound; } - public void AddSelectedMoviePropertys() + public void AddSelectedMoviePropertys(string SelectedItem) { string strIMDBID = Utils.GetProperty("#imdbnumber"); if (string.IsNullOrEmpty(strIMDBID)) @@ -850,6 +854,26 @@ public void AddSelectedMoviePropertys() strIMDBID = Utils.GetProperty("#myfilms.db.imdb_id.value"); } + // Trakt does not clear the #Trakt.Movie.ImdbId value so exit function when Trakt page and SelectedItem is null, or ClearArt will turn up when it should not + if (SelectedItem == "TraktIsNull") + return; + + if (string.IsNullOrEmpty(strIMDBID)) + { + strIMDBID = Utils.GetProperty("#Trakt.Movie.ImdbId"); + } + + string strTVDBID = Utils.GetProperty("#Trakt.Show.TvdbId"); + if (string.IsNullOrEmpty(strTVDBID)) + { + strTVDBID = Utils.GetProperty("#TVSeries.Series.ID"); + } + //if (string.IsNullOrEmpty(strTVDBID)) + //{ + // // TV Series ID + // strTVDBID = UtilsTVSeries.GetTVSeriesID(50); + //} + if (!string.IsNullOrEmpty(strIMDBID)) { Utils.SetProperty("movie.animated.selected.thumb", @@ -865,8 +889,25 @@ public void AddSelectedMoviePropertys() Utils.FanartTVFileExists(strIMDBID, null, null, Utils.FanartTV.MoviesBanner) ? Utils.GetFanartTVFileName(strIMDBID, null, null, Utils.FanartTV.MoviesBanner) : string.Empty); Utils.SetProperty("movie.cd.selected", Utils.FanartTVFileExists(strIMDBID, null, null, Utils.FanartTV.MoviesCDArt) ? Utils.GetFanartTVFileName(strIMDBID, null, null, Utils.FanartTV.MoviesCDArt) : string.Empty); + FanartAvailable = FanartAvailable || + Utils.AnimatedFileExists(strIMDBID, null, null, Utils.Animated.MoviesPoster) || + Utils.AnimatedFileExists(strIMDBID, null, null, Utils.Animated.MoviesBackground) || + Utils.FanartTVFileExists(strIMDBID, null, null, Utils.FanartTV.MoviesClearArt) || + Utils.FanartTVFileExists(strIMDBID, null, null, Utils.FanartTV.MoviesClearLogo) || + Utils.FanartTVFileExists(strIMDBID, null, null, Utils.FanartTV.MoviesBanner) || + Utils.FanartTVFileExists(strIMDBID, null, null, Utils.FanartTV.MoviesCDArt); } - else + if (!string.IsNullOrEmpty(strTVDBID)) + { + Utils.SetProperty("series.clearart.selected", + Utils.FanartTVFileExists(strTVDBID, null, null, Utils.FanartTV.SeriesClearArt) ? Utils.GetFanartTVFileName(strTVDBID, null, null, Utils.FanartTV.SeriesClearArt) : string.Empty); + Utils.SetProperty("series.clearlogo.selected", + Utils.FanartTVFileExists(strTVDBID, null, null, Utils.FanartTV.SeriesClearLogo) ? Utils.GetFanartTVFileName(strTVDBID, null, null, Utils.FanartTV.SeriesClearLogo) : string.Empty); + FanartAvailable = FanartAvailable || + Utils.FanartTVFileExists(strTVDBID, null, null, Utils.FanartTV.SeriesClearArt) || + Utils.FanartTVFileExists(strTVDBID, null, null, Utils.FanartTV.SeriesClearLogo); + } + if (string.IsNullOrEmpty(strIMDBID) && string.IsNullOrEmpty(strTVDBID)) { ClearSelectedMoviePropertys(); } @@ -880,6 +921,9 @@ public void ClearSelectedMoviePropertys() Utils.SetProperty("movie.clearlogo.selected", string.Empty); Utils.SetProperty("movie.banner.selected", string.Empty); Utils.SetProperty("movie.cd.selected", string.Empty); + + Utils.SetProperty("series.clearart.selected", string.Empty); + Utils.SetProperty("series.clearlogo.selected", string.Empty); } private void EmptyMusicProperties(bool currClean = true) diff --git a/FanartHandler/Utils.cs b/FanartHandler/Utils.cs index 9fd7c47..c440517 100644 --- a/FanartHandler/Utils.cs +++ b/FanartHandler/Utils.cs @@ -823,7 +823,13 @@ public static void InitFolders() { MoviesClearArtFolder = Path.Combine(MPThumbsFolder, @"Movies\ClearArt\FullSize\"); // DVDArt if (!Directory.Exists(MoviesClearArtFolder) || IsDirectoryEmpty(MoviesClearArtFolder)) - MoviesClearArtFolder = string.Empty; + { + MoviesClearArtFolder = Path.Combine(MPThumbsFolder, @"MovingPictures\ClearArt\FullSize\"); // Moving Pictures + if (!Directory.Exists(MoviesClearArtFolder) || IsDirectoryEmpty(MoviesClearArtFolder)) + { + MoviesClearArtFolder = string.Empty; + } + } } if (!string.IsNullOrEmpty(MoviesClearArtFolder)) { @@ -847,7 +853,13 @@ public static void InitFolders() { MoviesCDArtFolder = Path.Combine(MPThumbsFolder, @"Movies\DVDArt\FullSize\"); // DVDArt if (!Directory.Exists(MoviesCDArtFolder) || IsDirectoryEmpty(MoviesCDArtFolder)) - MoviesCDArtFolder = string.Empty; + { + MoviesCDArtFolder = Path.Combine(MPThumbsFolder, @"MovingPictures\DVDArt\FullSize\"); // Moving Pictures + if (!Directory.Exists(MoviesCDArtFolder) || IsDirectoryEmpty(MoviesCDArtFolder)) + { + MoviesCDArtFolder = string.Empty; + } + } } if (!string.IsNullOrEmpty(MoviesCDArtFolder)) { @@ -859,7 +871,13 @@ public static void InitFolders() { MoviesClearLogoFolder = Path.Combine(MPThumbsFolder, @"Movies\ClearLogo\FullSize\"); // DVDArt if (!Directory.Exists(MoviesClearLogoFolder) || IsDirectoryEmpty(MoviesClearLogoFolder)) - MoviesClearLogoFolder = string.Empty; + { + MoviesClearLogoFolder = Path.Combine(MPThumbsFolder, @"MovingPictures\ClearLogo\FullSize\"); // Moving Pictures + if (!Directory.Exists(MoviesClearLogoFolder) || IsDirectoryEmpty(MoviesClearLogoFolder)) + { + MoviesClearLogoFolder = string.Empty; + } + } } if (!string.IsNullOrEmpty(MoviesClearLogoFolder)) { @@ -2568,7 +2586,7 @@ public static void GetSelectedItem(ref string SelectedItem, ref string SelectedA } else if (iActiveWindow == 96742) // Moving Pictures { - SelectedItem = Utils.GetProperty("#selecteditem"); + SelectedItem = Utils.GetProperty("#MovingPictures.SelectedMovie.title"); SelectedStudios = Utils.GetProperty("#MovingPictures.SelectedMovie.studios"); SelectedGenre = Utils.GetProperty("#MovingPictures.SelectedMovie.genres"); // logger.Debug("*** "+SelectedItem+" - "+SelectedStudios+" - "+SelectedGenre); @@ -2634,6 +2652,44 @@ public static void GetSelectedItem(ref string SelectedItem, ref string SelectedA } catch { } } + else if (iActiveWindow == 87266 || // Trakt Trending Movies + iActiveWindow == 87700 || // Trakt Calendar Movies + iActiveWindow == 87101 || // Trakt Popular Movies + iActiveWindow == 87263 || // Trakt Recommendations Movies + iActiveWindow == 87605 || // Trakt Anticipated Movies + iActiveWindow == 87607 || // Trakt Box Office + iActiveWindow == 87265 || // Trakt Trending Series + iActiveWindow == 87102 || // Trakt Popular Series + iActiveWindow == 87262 || // Trakt Recommendations Series + iActiveWindow == 87259 || // Trakt Calendar Series + iActiveWindow == 87606 || // Trakt Anticipated Series + iActiveWindow == 87281 || // Trakt Series Seasons + iActiveWindow == 87282) // Trakt Series Episodes + { + SelectedItem = Utils.GetProperty("#selecteditem"); + // Remove ClearArt on Trakt Folders + var window = GUIWindowManager.GetWindow(Utils.iActiveWindow); + if (window != null) + { + var selectedListItem = GUIControl.GetSelectedListItem(Utils.iActiveWindow, window.GetFocusControlId()); + if (selectedListItem != null) // (selectedListItem != null || selectedListItem.IsFolder) + { + if (selectedListItem.IsFolder) + { + GUIControl cntl = window.GetControl(50); + if (cntl is GUIFacadeControl) + { + SelectedItem = string.Empty; + } + } + } + else + { + // Trakt menu is a null SelectedItem but we dont want to clear the SelectedItem when a movie is selected + SelectedItem = "TraktIsNull"; + } + } + } else SelectedItem = Utils.GetProperty("#selecteditem"); diff --git a/FanartHandler/UtilsTVSeries.cs b/FanartHandler/UtilsTVSeries.cs index 9aa3ce5..5804ecf 100644 --- a/FanartHandler/UtilsTVSeries.cs +++ b/FanartHandler/UtilsTVSeries.cs @@ -209,6 +209,34 @@ internal static string GetTVSeriesID(string tvSeriesName) // -> TV Series ID .. return result; } + internal static string GetTVSeriesID(int ControlID) // -> TV Series ID ... + { + if (!Utils.TVSeriesEnabled) + { + return string.Empty; + } + if (Utils.iActiveWindow != 9811 && // TVSeries + Utils.iActiveWindow != 9813) // TVSeries Playlist + { + return string.Empty; + } + var window = GUIWindowManager.GetWindow(Utils.iActiveWindow); + GUIControl cntl = window.GetControl(50); + if (cntl != null && cntl is GUIFacadeControl) + { + GUIListItem selectedListItem = (cntl as GUIFacadeControl).SelectedListItem; + if (selectedListItem != null) + { + DBSeries series = selectedListItem.TVTag as DBSeries; + if (series != null) + { + return series[DBOnlineSeries.cID]; + } + } + } + return string.Empty; + } + internal static string GetTVSeriesAttributes(GUIListItem currentitem, ref string sGenre, ref string sStudio) // -> TV Series name ... { if (!Utils.TVSeriesEnabled)