mirror of
https://github.com/Radarr/Radarr
synced 2024-12-30 11:55:18 +00:00
9714a96437
Series/Details season grids won't be as tall now, due to reduced padding.
183 lines
7.4 KiB
Text
183 lines
7.4 KiB
Text
@model SeriesModel
|
|
@using NzbDrone.Web.Models
|
|
@section TitleContent{
|
|
@Model.Title
|
|
}
|
|
|
|
<script src="../../Scripts/seriesDetails.js" type="text/javascript"></script>
|
|
|
|
<style>
|
|
.seasonToggleTopGroup
|
|
{
|
|
overflow: hidden;
|
|
width: 50%;
|
|
}
|
|
|
|
.seasonToggleTop
|
|
{
|
|
background-color: #F1EDED;
|
|
background-position: 5px center;
|
|
background-repeat: no-repeat;
|
|
display: inline-block;
|
|
font-size: 15px;
|
|
margin: 2px;
|
|
padding: 2px 5px;
|
|
width: 100px;
|
|
}
|
|
|
|
.seasonToggleLabel
|
|
{
|
|
margin-left: 5px;
|
|
}
|
|
|
|
.seasonToggleTop .ignoredEpisodesMaster
|
|
{
|
|
padding-left: 0px;
|
|
padding-right: 0px;
|
|
margin-bottom: -4px;
|
|
border-style: none;
|
|
}
|
|
|
|
.statusImage, .searchImage, .renameImage, .ignoreEpisode, .ignoreEpisodesMaster
|
|
{
|
|
width: 18px;
|
|
height: 18px;
|
|
padding: 1px;
|
|
margin: 2px;
|
|
border-width: 1px;
|
|
border-style: dashed;
|
|
border-color: lightgray;
|
|
}
|
|
|
|
.searchImage:hover, .renameImage:hover, .ignoreEpisode:hover, .ignoreEpisodesMaster:hover
|
|
{
|
|
background-color: #065EFE;
|
|
}
|
|
|
|
.t-grid td
|
|
{
|
|
line-height: 0.6em;
|
|
}
|
|
|
|
.t-grid .t-header
|
|
{
|
|
line-height: 1.8em;
|
|
}
|
|
|
|
.t-grid-header .t-header .t-link
|
|
{
|
|
padding: 0.3em 0.9em 1.0em 0.6em;
|
|
}
|
|
|
|
.t-grid .t-detail-cell
|
|
{
|
|
line-height: 1.5em;
|
|
}
|
|
|
|
.t-grid td
|
|
{
|
|
padding: 0 0.6em;
|
|
}
|
|
|
|
#banner-container
|
|
{
|
|
width: 758px;
|
|
height: 140px;
|
|
padding: 0px;
|
|
margin-top: 10px;
|
|
margin-bottom: 15px;
|
|
margin-left: auto;
|
|
margin-right: auto;
|
|
}
|
|
</style>
|
|
|
|
@section ActionMenu{
|
|
<ul class="sub-menu">
|
|
<li>@Html.ActionLink("Back to Series List", "Index", "Series")</li>
|
|
<li>@Ajax.ActionLink("Scan For Episodes on Disk", "SyncEpisodesOnDisk", "Command", new { seriesId = Model.SeriesId }, null)</li>
|
|
<li>@Ajax.ActionLink("Update Info", "UpdateInfo", "Command", new { seriesId = Model.SeriesId }, null)</li>
|
|
<li>@Ajax.ActionLink("Search for Series", "SearchSeries", "Episode", new { seriesId = Model.SeriesId }, null)</li>
|
|
<li>@Ajax.ActionLink("Rename Series", "RenameSeries", "Episode", new { seriesId = Model.SeriesId }, null)</li>
|
|
</ul>
|
|
}
|
|
@section MainContent{
|
|
<div id="banner-container">
|
|
@{
|
|
var bannerUrl = "../../Content/Images/img03.jpg";
|
|
|
|
if(Model.HasBanner)
|
|
{
|
|
bannerUrl = "../../Content/Images/Banners/" + Model.SeriesId + ".jpg";
|
|
}
|
|
}
|
|
<img src="@bannerUrl" alt="Banner"/>
|
|
</div>
|
|
|
|
<div class="seasonToggleTopGroup">
|
|
@foreach (var season in Model.Seasons)
|
|
{
|
|
var ignoreSeason = "ignoreSeason_" + season;
|
|
<div class="seasonToggleTop">
|
|
<img src='../../Content/Images/ignoredNeutral.png' class='ignoredEpisodesMaster ignoreEpisode @ignoreSeason' title='Click to toggle season ignore status' />
|
|
<span class="seasonToggleLabel">@(season == 0 ? "Specials" : "Season " + season)</span>
|
|
</div>
|
|
}
|
|
</div>
|
|
|
|
@foreach (var s in Model.Seasons.Reverse())
|
|
{
|
|
var seriesId = @Model.SeriesId;
|
|
var season = s;
|
|
|
|
<h3>
|
|
@(season == 0 ? "Specials" : "Season " + season)
|
|
</h3>
|
|
|
|
<div class="grid-container">
|
|
@{
|
|
Html.Telerik().Grid<EpisodeModel>().Name("seasons_" + season)
|
|
.TableHtmlAttributes(new { @class = "Grid" })
|
|
.Columns(columns =>
|
|
{
|
|
columns.Bound(c => c.EpisodeNumber).Width(0).Title("Episode");
|
|
columns.Bound(c => c.Title).Title("Title");
|
|
columns.Bound(c => c.AirDate).Width(0);
|
|
columns.Bound(c => c.Quality).Width(0);
|
|
columns.Bound(c => c.Status)
|
|
.Title("<img src='../../Content/Images/ignoredNeutral.png' class='ignoredEpisodesMaster ignoreEpisode ignoreSeason_" + season + "' title='Click to toggle season ignore status' />" +
|
|
"<img src='../../Content/Images/Missing.png' alt='Status' title='Season Status' class='statusImage statusImageMaster' />" +
|
|
"<a href=\"../Episode/SearchSeason?seriesId=" + @seriesId + "&seasonNumber=" + @season + "\" onclick=\"searchSeason(" + @seriesId + ", "+ @season + "); return false;\"><img src='../../Content/Images/Search.png' alt='Search' title='Search for all episodes in this season' class='searchImage searchImageMaster' /></a>" +
|
|
"<a href=\"../Episode/RenameSeason?seriesId=" + @seriesId + "&seasonNumber=" + @season + "\" onclick=\"renameSeason(" + @seriesId + ", " + @season + "); return false;\"><img src='../../Content/Images/Rename.png' alt='Rename' title='Rename all episodes in this season' class=renameImage renameImageMaster' /></a>")
|
|
.ClientTemplate("<img src='../../Content/Images/ignoredNeutral.png' class='ignoreEpisode ignoreEpisode_" + season + " ignored' id='<#= EpisodeId #>' title='Click to toggle episode ignore status' />" +
|
|
"<img src='../../Content/Images/<#= Status #>.png' alt='<#= Status #>' title='<#= Status #>' class='statusImage status-<#= Status #>' />" +
|
|
"<a href=\"../Episode/Season?episodeId=<#= EpisodeId #>\" onclick=\"searchForEpisode('<#= EpisodeId #>'); return false;\"><img src='../../Content/Images/Search.png' alt='Search' title='Search for episode' class='searchImage' /></a>" +
|
|
"<a href=\"../Episode/Rename?episodeFileId=<#= EpisodeId #>\" onclick=\"renameEpisode('<#= EpisodeFileId #>'); return false;\"><img src='../../Content/Images/Rename.png' alt='Rename' title='Rename episode' class='renameImage' />")
|
|
.Width(80);
|
|
})
|
|
.DetailView(detailView => detailView.ClientTemplate("<div><#= Overview #> </br><#= Path #> </div>"))
|
|
.Sortable(rows => rows.OrderBy(epSort => epSort.Add(c => c.EpisodeNumber).Descending()).Enabled(false))
|
|
.Footer(true)
|
|
.DataBinding(
|
|
d =>
|
|
d.Ajax().Select("_AjaxSeasonGrid", "Series",
|
|
new RouteValueDictionary { { "seriesId", Model.SeriesId }, { "seasonNumber", season } }))
|
|
@*.ToolBar(toolbar => toolbar.Template(@<text>
|
|
<ul class="sub-menu">
|
|
<li><a href="../Episode/SearchSeason?seriesId=@seriesId&seasonNumber=@season" onclick="searchSeason('@seriesId', @season); return false;">Search for Season</a></li>
|
|
<li><a href="../Episode/RenameSeason?seriesId=@seriesId&seasonNumber=@season" onclick="renameSeason('@seriesId', @season); return false;">Rename Season</a></li>
|
|
</ul>
|
|
</text>))*@
|
|
.ClientEvents(clientEvents =>
|
|
{
|
|
clientEvents.OnRowDataBound("grid_rowBound");
|
|
clientEvents.OnDataBound("grid_dataBound");
|
|
})
|
|
.Render();}
|
|
</div>
|
|
}
|
|
}
|
|
@section Scripts{
|
|
<script type="text/javascript">
|
|
seriesId = @Model.SeriesId;
|
|
</script>
|
|
}
|