private static string CreateHtml([NotNull] ShowItem si) { SeriesInfo series = si.TheSeries(); if (series is null) { return(string.Empty); } string posterUrl = TheTVDB.API.GetImageURL(series.GetImage(TVSettings.FolderJpgIsType.Poster)); string yearRange = ShowHtmlHelper.YearRange(series); string episodeSummary = series.Episodes.Count.ToString(); string stars = ShowHtmlHelper.StarRating(series.SiteRating / 2); string genreIcons = string.Join(" ", series.Genres().Select(ShowHtmlHelper.GenreIconHtml)); string siteRating = series.SiteRating > 0 ? series.SiteRating + "/10" : ""; return($@"<div class=""card card-body""> <div class=""row""> <div class=""col-md-4""> <img class=""show-poster rounded w-100"" src=""{posterUrl}"" alt=""{si.ShowName} Show Poster""></div> <div class=""col-md-8 d-flex flex-column""> <div class=""row""> <div class=""col-md-8""><h1>{si.ShowName}</h1></div> <div class=""col-md-4 text-right""><h6>{yearRange} ({series.Status})</h6><small class=""text-muted"">{episodeSummary} Episodes</small></div> </div> <div><blockquote>{series.Overview}</blockquote></div> <div><blockquote>{series.GetActorNames().ToCsv()}</blockquote></div> <div class=""row align-items-bottom flex-grow-1""> <div class=""col-md-4 align-self-end"">{stars}<br>{siteRating}</div> <div class=""col-md-4 align-self-end text-center"">{series.ContentRating}<br>{series.Network}</div> <div class=""col-md-4 align-self-end text-right"">{genreIcons}<br>{series.Genres().ToCsv()}</div> </div> </div></div></div>"); }
private static void AppendShow(this StringBuilder sb, [CanBeNull] ShowItem si, Color backgroundColour, bool includeDirectoryLinks) { SeriesInfo ser = si?.TheSeries(); if (ser is null) { return; } string horizontalBanner = CreateHorizontalBannerHtml(ser); string poster = CreatePosterHtml(ser); string yearRange = YearRange(ser); string episodeSummary = ser.AiredSeasons.Sum(pair => pair.Value.Episodes.Count).ToString(); string stars = StarRating(ser.SiteRating / 2); string genreIcons = string.Join(" ", ser.Genres().Select(GenreIconHtml)); string siteRating = ser.SiteRating > 0 ? ser.SiteRating + "/10" : ""; string runTimeHtml = string.IsNullOrWhiteSpace(ser.Runtime) ? string.Empty : $"<br/> {ser.Runtime} min"; string actorLinks = string.Join(", ", ser.GetActors().Select(ActorLinkHtml)); string tvdbLink = TheTVDB.Instance.WebsiteUrl(si.TvdbCode, -1, true); string airsTime = ParseAirsTime(ser); string airsDay = ser.AirsDay; string dayTime = $"{airsDay} {airsTime}"; string tvLink = string.IsNullOrWhiteSpace(ser.SeriesId) ? string.Empty : "http://www.tv.com/show/" + ser.SeriesId + "/summary.html"; string imdbLink = string.IsNullOrWhiteSpace(ser.Imdb) ? string.Empty : "http://www.imdb.com/title/" + ser.Imdb; string urlFilename = includeDirectoryLinks ? Uri.EscapeDataString(si.GetBestFolderLocationToOpen()) : string.Empty; string explorerButton = includeDirectoryLinks ? CreateButton($"{UI.EXPLORE_PROXY}{urlFilename}", "<i class=\"far fa-folder-open\"></i>", "Open Containing Folder") : string.Empty; sb.AppendLine($@"<div class=""card card-body"" style=""background-color:{backgroundColour.HexColour()}""> <div class=""text-center""> {horizontalBanner} </div> <div class=""row""> <div class=""col-md-4""> {poster} </div> <div class=""col-md-8 d-flex flex-column""> <div class=""row""> <div class=""col-md-8""><h1>{ser.Name}</h1></div> <div class=""col-md-4 text-right""><h6>{yearRange} ({ser.Status})</h6><small class=""text-muted"">{episodeSummary} Episodes{runTimeHtml}</small></div> </div> <div><p class=""lead"">{ser.Overview}</p></div> <div><blockquote>{actorLinks}</blockquote></div> <div> {explorerButton} {CreateButton(tvdbLink, "TVDB.com", "View on TVDB")} {CreateButton(imdbLink, "IMDB.com", "View on IMDB")} {CreateButton(tvLink, "TV.com", "View on TV.com")} </div> <div> </div> <div class=""row align-items-bottom""> <div class=""col-md-4 align-self-end"">{stars}<br>{siteRating}{AddRatingCount(ser.SiteRatingVotes)}</div> <div class=""col-md-4 align-self-end text-center"">{ser.ContentRating}<br>{ser.Network}, {dayTime}</div> <div class=""col-md-4 align-self-end text-right"">{genreIcons}<br>{string.Join(", ", ser.Genres())}</div> </div> </div> </div> </div>"); //Ideally we'd have <div class=""row align-items-bottom flex-grow-1""> in there as it looks better, but a bug in IE prevents it from looking correct }