Series grid updated to remove Telerik MVC Grid.

pull/2/head
Mark McDowall 13 years ago
parent ea86ce2fcb
commit a330348c8e

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

@ -279,3 +279,50 @@ button span, input[type="button"] span, input[type="submit"] span, input[type="r
{ {
background-color: #F5A9A9; background-color: #F5A9A9;
} }
.seriesTable
{
width: 100%;
border-width: 1px;
border-spacing: 2px;
border-style: none;
border-color: white;
border-collapse: collapse;
}
.seriesTable th
{
font-family: "Segoe UI Light" , "Open Sans" , "Segoe UI" , sans-serif;
border-width: 300;
font-size: 17px;
padding: 2px;
border-style: inset;
border-color: #EEEEEE;
padding-left: 7px;
text-align: left;
background-color: white;
font-weight: lighter;
}
.seriesTable td
{
border-width: 1px;
padding: 0px 8px 0px 8px;
border-style: inset;
border-color: #EEEEEE;
}
.detail-view
{
display: none;
}
/* Colour alternating rows */
.seriesTable tr:nth-child(4n)
{
background: #f0f5ff;
}
.seriesTable tr:nth-child(4n+1)
{
background: #f0f5ff;
}

@ -26,6 +26,11 @@
color: #065EFE; color: #065EFE;
} }
.ui-progressbar-value
{
background: #065EFE url(./jQueryUI/images/ui-bg_flat_30_065efe_40x100.png) 50% 50% repeat-x;
}
.jquery-tabs .jquery-tabs
{ {
margin-top: 10px; margin-top: 10px;

@ -37,6 +37,12 @@ namespace NzbDrone.Web.Controllers
} }
public ActionResult Index() public ActionResult Index()
{
var series = GetSeriesModels(_seriesProvider.GetAllSeriesWithEpisodeCount()).OrderBy(o => SortHelper.SkipArticles(o.Title));
return View(series);
}
public ActionResult SeriesEditor(int seriesId)
{ {
var profiles = _qualityProvider.All(); var profiles = _qualityProvider.All();
ViewData["SelectList"] = new SelectList(profiles, "QualityProfileId", "Name"); ViewData["SelectList"] = new SelectList(profiles, "QualityProfileId", "Name");
@ -50,47 +56,31 @@ namespace NzbDrone.Web.Controllers
ViewData["BacklogSettingSelectList"] = new SelectList(backlogStatusTypes, "Key", "Value"); ViewData["BacklogSettingSelectList"] = new SelectList(backlogStatusTypes, "Key", "Value");
return View(); var series = GetSeriesModels(new List<Series>{_seriesProvider.GetSeries(seriesId)}).Single();
} return View(series);
[GridAction]
public ActionResult _AjaxSeriesGrid()
{
var series = GetSeriesModels(_seriesProvider.GetAllSeriesWithEpisodeCount()).OrderBy(o => SortHelper.SkipArticles(o.Title));
return View(new GridModel(series));
} }
[AcceptVerbs(HttpVerbs.Post)] [HttpPost]
[GridAction] public JsonResult SaveSeriesEditor(SeriesModel seriesModel)
public ActionResult _SaveAjaxSeriesEditing(int id, string path, bool monitored, bool seasonFolder, int qualityProfileId, int backlogSetting)
{ {
var oldSeries = _seriesProvider.GetSeries(id); var series = _seriesProvider.GetSeries(seriesModel.SeriesId);
oldSeries.Monitored = monitored; series.Monitored = seriesModel.Monitored;
oldSeries.SeasonFolder = seasonFolder; series.SeasonFolder = seriesModel.SeasonFolder;
oldSeries.QualityProfileId = qualityProfileId; series.QualityProfileId = seriesModel.QualityProfileId;
oldSeries.Path = path; series.Path = seriesModel.Path;
oldSeries.BacklogSetting = (BacklogSettingType)backlogSetting; series.BacklogSetting = (BacklogSettingType)seriesModel.BacklogSetting;
_seriesProvider.UpdateSeries(oldSeries); _seriesProvider.UpdateSeries(series);
var series = GetSeriesModels(_seriesProvider.GetAllSeriesWithEpisodeCount()).OrderBy(o => SortHelper.SkipArticles(o.Title)); return JsonNotificationResult.Info("Series Saved");
return View(new GridModel(series));
} }
[GridAction] [HttpPost]
public ActionResult _DeleteAjaxSeriesEditing(int id) public JsonResult DeleteSeries(int seriesId)
{ {
//Grab the series from the DB so we can remove it from the list we return to the client _jobProvider.QueueJob(typeof(DeleteSeriesJob), seriesId);
var seriesInDb = _seriesProvider.GetAllSeriesWithEpisodeCount().ToList();
//Remove this so we don't send it back to the client (since it hasn't really been deleted yet)
seriesInDb.RemoveAll(s => s.SeriesId == id);
//Start removing this series
_jobProvider.QueueJob(typeof(DeleteSeriesJob), id);
var series = GetSeriesModels(seriesInDb).OrderBy(o => SortHelper.SkipArticles(o.Title)); return JsonNotificationResult.Info("Series Deleted");
return View(new GridModel(series));
} }
public JsonResult LocalSearch(string term) public JsonResult LocalSearch(string term)

@ -142,6 +142,7 @@
<Content Include="Content\2011.3.1115\telerik.sitefinity.min.css" /> <Content Include="Content\2011.3.1115\telerik.sitefinity.min.css" />
<Content Include="Content\Images\background.jpg" /> <Content Include="Content\Images\background.jpg" />
<Content Include="Content\Images\blue.png" /> <Content Include="Content\Images\blue.png" />
<Content Include="Content\Images\Delete.png" />
<Content Include="Content\Images\Gear.png" /> <Content Include="Content\Images\Gear.png" />
<Content Include="Content\Images\green.png" /> <Content Include="Content\Images\green.png" />
<Content Include="Content\Images\header.jpg" /> <Content Include="Content\Images\header.jpg" />
@ -455,9 +456,6 @@
<ItemGroup> <ItemGroup>
<Content Include="Views\Missing\Index.cshtml" /> <Content Include="Views\Missing\Index.cshtml" />
</ItemGroup> </ItemGroup>
<ItemGroup>
<Content Include="Views\Series\EditorTemplates\SeriesModel.cshtml" />
</ItemGroup>
<ItemGroup> <ItemGroup>
<Content Include="Views\AddSeries\ExistingSeries.cshtml" /> <Content Include="Views\AddSeries\ExistingSeries.cshtml" />
</ItemGroup> </ItemGroup>
@ -548,6 +546,12 @@
<ItemGroup> <ItemGroup>
<Content Include="Views\Series\Details.cshtml" /> <Content Include="Views\Series\Details.cshtml" />
</ItemGroup> </ItemGroup>
<ItemGroup>
<Content Include="Views\Series\Series.cshtml" />
</ItemGroup>
<ItemGroup>
<Content Include="Views\Series\SeriesEditor.cshtml" />
</ItemGroup>
<Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" /> <Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
<Import Project="$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v10.0\WebApplications\Microsoft.WebApplication.targets" /> <Import Project="$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v10.0\WebApplications\Microsoft.WebApplication.targets" />
<!-- To modify your build process, add your task inside one of the targets below and uncomment it. <!-- To modify your build process, add your task inside one of the targets below and uncomment it.

@ -1,4 +1,15 @@
function grid_onError(e) { /* Click on row, show details */
$('.seriesTable a').live('click', function () {
var link = $(this).attr('href');
window.location = link;
event.preventDefault();
});
$('.seriesTable tr td:not(:last-child)').live('click', function () {
$(this).parent('tr').next('.detail-view').toggle();
});
function grid_onError(e) {
//Suppress the alert //Suppress the alert
e.preventDefault(); e.preventDefault();
} }

@ -144,8 +144,3 @@ function saveEpisodeIgnore(episodeId, ignored) {
} }
}); });
} }
/* Click on row, show details */
$('.seriesTable tr td:not(:last-child)').live('click', function () {
$(this).parent('tr').next('.detail-view').toggle();
});

@ -157,6 +157,7 @@
} }
@section Scripts{ @section Scripts{
@Html.IncludeScript("NzbDrone/seriesDetails.js") @Html.IncludeScript("NzbDrone/seriesDetails.js")
@Html.IncludeScript("NzbDrone/grid.js")
<script type="text/javascript"> <script type="text/javascript">
seriesId = @Model.SeriesId; seriesId = @Model.SeriesId;
</script> </script>

@ -1,7 +1,7 @@
@using NzbDrone.Common @using NzbDrone.Common
@using NzbDrone.Web.Helpers @using NzbDrone.Web.Helpers
@using NzbDrone.Web.Models; @using NzbDrone.Web.Models;
@model IEnumerable<NzbDrone.Core.Repository.Series> @model IEnumerable<NzbDrone.Web.Models.SeriesModel>
@{ViewBag.Title = "NzbDrone";} @{ViewBag.Title = "NzbDrone";}
@section HeaderContent @section HeaderContent
@ -9,45 +9,55 @@
@Html.IncludeCss("Settings.css") @Html.IncludeCss("Settings.css")
} }
<style> <style>
/* progress bar container */ .ui-progressbar
.progressbar
{ {
border: 1px solid #065EFE; position:relative;
width: 125px; width: 125px;
height: 20px; height: 20px;
position: relative; background-color: transparent;
color: black; border: 1px solid #065EFE;
margin: 2px;
} }
.progressBarText
/* color bar */
.progressbar div.progress
{ {
position: absolute; position: absolute;
width: 0; display: block;
height: 100%; width: 100%;
text-align: center;
}
.ui-progressbar-value
{
overflow: hidden; overflow: hidden;
background-color: #065EFE; border: 1px solid #065EFE;
} }
/* text on bar */
.progressbar div.progress .progressText .ui-progressbar-value .progressBarText
{ {
position: absolute; position: relative;
text-align: center; font-weight: normal;
color: white; color: white;
} }
/* text off bar */
.progressbar div.progressText /* Set the row height so it won't resize when the progress bar is created */
.seriesTable tr
{ {
position: absolute; height: 28px;
width: 100%;
height: 100%;
text-align: center;
} }
.t-grid .t-alt .editButton, .deleteButton
{ {
background: #E5ECF9; width: 18px;
height: 18px;
padding: 3px 1px;
margin: 0px;
vertical-align: middle;
}
.editButton:hover, .deleteButton:hover
{
background-color: #065EFE;
} }
</style> </style>
@section ActionMenu{ @section ActionMenu{
@ -56,90 +66,147 @@
<li>@Ajax.ActionLink("Start RSS Sync", "RssSync", "Command", null)</li> <li>@Ajax.ActionLink("Start RSS Sync", "RssSync", "Command", null)</li>
</ul> </ul>
} }
@{Html.Telerik().Grid<SeriesModel>().Name("Grid")
.DataKeys(keys => keys.Add(p => p.SeriesId)) <table class="seriesTable">
.DataBinding(data => data.Ajax() <colgroup>
.Select("_AjaxSeriesGrid", "Series") <col/>
.Update("_SaveAjaxSeriesEditing", "Series") <col style="width:100px" />
.Delete("_DeleteAjaxSeriesEditing", "Series")) <col style="width:100px" />
.Columns(columns => <col style="width:100px" />
{ <col style="width:100px" />
columns.Bound(o => o.Title) <col style="width:140px" />
.ClientTemplate("<a href=" + <col style="width:100px" />
Url.Action("Details", "Series", new { seriesId = "<#= SeriesId #>" }) + </colgroup>
"><#= Title #></a>"); <tr>
columns.Bound(o => o.SeasonsCount).Title("Seasons"); <th>Title</th>
columns.Bound(o => o.QualityProfileName).Title("Quality"); <th>Seasons</th>
columns.Bound(o => o.Status); <th>Quality</th>
//columns.Bound(o => o.AirsDayOfWeek); <th>Status</th>
columns.Bound(o => o.NextAiring); <th>Next Airing</th>
columns.Bound(o => o.Episodes).Title("Episodes").Width(125) <th>Episodes</th>
.ClientTemplate("<div id=\"progressbar_<#= SeriesId #>\" class=\"progressbar\">" +
"<div class=\"progressText\"></div>" + @*Commands Column*@
"<div class=\"progress\">" + <th>
"<span class=\"progressText\" style=\"width: 125px;\"></span>" + Commands
"</div>" + </th>
"</div>"); </tr>
columns.Command(commands => @foreach (var series in Model)
{ {
commands.Edit().ButtonType(GridButtonType.Image); Html.RenderPartial("Series", series);
commands.Delete().ButtonType(GridButtonType.Image); }
}).Title("Actions").Width(90); </table>
}) <div id="seriesEditor" title="Edit Series"></div>
.Editable(editor => editor.Mode(GridEditMode.PopUp)) <div id="seriesDelete" title="Delete Series">
.DetailView(detailView => detailView.ClientTemplate( <input class="seriesId" type="hidden" value="">
"<b>Airs Day of Week:</b> " + "<#= AirsDayOfWeek #>" + Are you sure you want to delete '<span class="seriesTitle"></span>'?
"<br />" + </div>
"<b>Overview:</b> " +
"<#= Overview #>"
))
.ClientEvents(clientEvents =>
{
clientEvents.OnEdit("grid_edit");
clientEvents.OnSave("grid_save");
clientEvents.OnRowDataBound("grid_rowBound");
if(EnviromentProvider.IsProduction)
clientEvents.OnError("grid_onError");
})
.Render();}
@section Scripts{ @section Scripts{
<script type="text/javascript"> <script type="text/javascript">
var windowElement; var seriesEditorUrl = './Series/SeriesEditor';
var saveSeriesEditorUrl = './Series/SaveSeriesEditor';
function grid_edit(args) { var seriesDeleteUrl = './Series/DeleteSeries';
$(args.form)
.closest(".t-window") $(document).ready(function () {
.data("tWindow") $(".progressBar").each(function () {
.center(); var element = this;
}
var progressbar = $(element).progressbar({
function grid_save(e) { value: parseInt($(element).attr("value"))
$('#ajaxSaveWheel').show();
}
function grid_rowBound(e) {
var dataItem = e.dataItem;
var seriesId = dataItem.SeriesId;
var episodeCount = dataItem.EpisodeCount;
var episodeFileCount = dataItem.EpisodeFileCount;
$("#progressbar_" + seriesId).episodeProgress(episodeFileCount, episodeCount);
}
(function ($) {
$.fn.episodeProgress = function (episodes, totalEpisodes) {
return this.each(
function () {
var div = $(this);
var progressBar = div.find(".progress");
var width = Math.round(episodes / totalEpisodes * 100);
progressBar.css("width", width + "%");
div.find(".progressText").html(episodes + " / " + totalEpisodes);
}); });
}; var label = progressbar.find('.progressBarText').clone().width(progressbar.width());
})(jQuery); progressbar.find('.ui-progressbar-value').append(label);
});
});
$("#seriesEditor").dialog({
autoOpen: false,
height: 350,
width: 670,
resizable: false,
modal: true,
buttons: {
"Save": function () {
//Save the form
$('#SeriesEditorForm').submit();
$(this).dialog("close");
},
Cancel: function () {
$(this).dialog("close");
}
}
});
$("#seriesDelete").dialog({
autoOpen: false,
resizable: false,
height: 170,
width: 450,
modal: true,
buttons: {
"Delete": function () {
var seriesId = $('.seriesId').val();
$.ajax({
type: "POST",
url: seriesDeleteUrl,
data: { seriesId: seriesId },
success: function (data) {
//Remove the row from the grid... along with the details row
$('.' + seriesId).hide();
$('.details_' + seriesId).hide();
}
});
$(this).dialog("close");
},
Cancel: function () {
$(this).dialog("close");
}
}
});
$(".editButton")
//.button()
.live('click', function () {
//Get the SeriesId and Title
var seriesId = parseInt($(this).attr("value"));
var title = $(this).attr("rel");
//Set the title of the dialog
$("#seriesEditor").dialog("option", "title", "Edit Series: " + title);
//Pre-populate the view with ajax
$('#seriesEditor').html('<div style="text-align: center; width: 100%; height: 100%;"><img src="../../Content/Images/ajax-loader.gif" style="padding-top: 120px;" /></div>');
//Get the view
$.ajax({
url: seriesEditorUrl,
data: { seriesId: seriesId },
success: function (data) {
$('#seriesEditor').html(data);
}
});
//Open the dialog
$("#seriesEditor").dialog("open");
});
$(".deleteButton")
//.button()
.live('click', function () {
//Get the SeriesId and Title
var seriesId = parseInt($(this).attr("value"));
var title = $(this).attr("rel");
//Set the title of the dialog
//$("#seriesDelete").dialog("option", "title", "Delete Series: " + title);
//Fill in the view
$('#seriesDelete').children('.seriesId').val(seriesId);
$('#seriesDelete').children('.seriesTitle').html(title);
//Open the dialog
$("#seriesDelete").dialog("open");
});
</script> </script>
} }

@ -0,0 +1,30 @@
@using NzbDrone.Web.Helpers
@model NzbDrone.Web.Models.SeriesModel
<tr class="@Model.SeriesId">
<td>@Html.ActionLink(Model.Title, "Details", "Series", new { seriesId = Model.SeriesId }, null)</td>
<td>@Model.SeasonsCount</td>
<td>@Model.QualityProfileName</td>
<td>@Model.Status</td>
<td>@Model.NextAiring</td>
<td>
@{ double progress = (double)Model.EpisodeFileCount / (double)Model.EpisodeCount * 100; }
<div class='progressBar' rel='@progress.ToString("0")'>
<span class='progressBarText'>@Model.EpisodeFileCount / @Model.EpisodeCount</span>
</div>
</td>
@*Commands Column*@
<td>
<img src="../../Content/Images/Rename.png" class="editButton" value="@Model.SeriesId" rel="@Model.Title" />
<img src="../../Content/Images/Delete.png" class="deleteButton" value="@Model.SeriesId" rel="@Model.Title" />
@*<div class="editButton" value="@Model.SeriesId" rel="@Model.Title">Edit</div>
<div class="deleteButton" value="@Model.SeriesId" rel="@Model.Title">Delete</div>*@
</td>
</tr>
<tr class="detail-view details_@(Model.SeriesId)">
<td colspan="7">
<b>Airs Day of Week:</b> @Model.AirsDayOfWeek <br/>
<b>Overview:</b> @Model.Overview
</td>
</tr>

@ -12,7 +12,8 @@
</style> </style>
<div id="stylized" style="border-color: transparent;"> <div id="stylized" style="border-color: transparent;">
<div class="settingsForm"> @using (Html.BeginForm("SaveSeriesEditor", "Series", FormMethod.Post, new { id = "SeriesEditorForm", name = "SeriesEditorForm", @class = "settingsForm" }))
{
@Html.HiddenFor(m => m.SeriesId) @Html.HiddenFor(m => m.SeriesId)
<label class="labelClass">@Html.LabelFor(m => m.Monitored) <label class="labelClass">@Html.LabelFor(m => m.Monitored)
<span class="small">@Html.DescriptionFor(m => m.Monitored)</span> <span class="small">@Html.DescriptionFor(m => m.Monitored)</span>
@ -27,12 +28,12 @@
</label> </label>
@Html.DropDownListFor(m => m.QualityProfileId, (SelectList)ViewData["SelectList"], new { @class = "inputClass" }) @Html.DropDownListFor(m => m.QualityProfileId, (SelectList)ViewData["SelectList"], new { @class = "inputClass" })
<label class="labelClass">@Html.LabelFor(m => m.Path) <label class="labelClass">@Html.LabelFor(m => m.Path)
<span class="small">@Html.DescriptionFor(m => m.Path)</span> <span class="small">@Html.DescriptionFor(m => m.Path)</span>
</label> </label>
@Html.TextBoxFor(m => m.Path, new { @class = "inputClass" }) @Html.TextBoxFor(m => m.Path, new { @class = "inputClass" })
<label class="labelClass">@Html.LabelFor(m => m.BacklogSetting) <label class="labelClass">@Html.LabelFor(m => m.BacklogSetting)
<span class="small">@Html.DescriptionFor(m => m.BacklogSetting)</span> <span class="small">@Html.DescriptionFor(m => m.BacklogSetting)</span>
</label> </label>
@Html.DropDownListFor(m => m.BacklogSetting, (SelectList)ViewData["BacklogSettingSelectList"], new { @class = "inputClass" }) @Html.DropDownListFor(m => m.BacklogSetting, (SelectList)ViewData["BacklogSettingSelectList"], new { @class = "inputClass" })
</div> }
</div> </div>
Loading…
Cancel
Save