From f27c1d89f63465d61f5451960a33ad1dfa656fdc Mon Sep 17 00:00:00 2001 From: Mark McDowall Date: Mon, 30 May 2011 23:13:46 -0700 Subject: [PATCH 1/3] Moved root dir config to add series. Cleaned up Indexers.cshtml. Indexers is the new default Settings page. --- NzbDrone.Web/Content/Images/VideoFolder.png | Bin 0 -> 1133 bytes NzbDrone.Web/Content/style.css | 2 +- .../Controllers/AddSeriesController.cs | 104 +++++++- .../Controllers/SettingsController.cs | 69 +---- NzbDrone.Web/NzbDrone.Web.csproj | 3 +- NzbDrone.Web/Views/AddSeries/Add.cshtml | 119 ++++++++- NzbDrone.Web/Views/AddSeries/AddNew.cshtml | 12 +- .../Views/AddSeries/AddSeriesItem.cshtml | 29 +-- NzbDrone.Web/Views/AddSeries/RootDir.cshtml | 16 ++ NzbDrone.Web/Views/Settings/General.cshtml | 88 ------- NzbDrone.Web/Views/Settings/Indexers.cshtml | 235 +++++++++--------- NzbDrone.Web/Views/Settings/RootDir.cshtml | 35 --- 12 files changed, 355 insertions(+), 357 deletions(-) create mode 100644 NzbDrone.Web/Content/Images/VideoFolder.png create mode 100644 NzbDrone.Web/Views/AddSeries/RootDir.cshtml delete mode 100644 NzbDrone.Web/Views/Settings/General.cshtml delete mode 100644 NzbDrone.Web/Views/Settings/RootDir.cshtml diff --git a/NzbDrone.Web/Content/Images/VideoFolder.png b/NzbDrone.Web/Content/Images/VideoFolder.png new file mode 100644 index 0000000000000000000000000000000000000000..566c41eb7cb3507d10adb99500b8edfb5d60c2cb GIT binary patch literal 1133 zcmV-z1d{uSP)z@;j(q!3lK=n!AY({UO#lFTB>(_`g8%^e{{R4h=>PzA zFaQARU;qF*m;eA5Z<1fdMgRZ<<4Ht8RCwBAOlxdp00G9o{}|YR{o`V1WBtd#!2R>y zoh$zj?Apf6z{sd1r=VamZTd834p!ECKyd8X#j6Z|fB$A+V`gFi2mnCF4PZ7Z@lA2?{O-2?+`D@9^dc7#Eb^} z0RaI2|Na01h=uXXcZPpJ+l8g1?8L;xRF^GX%JAdoPjx0{76wrXNuWALhMzxvFkHHF zS%{CHul()X_X#Zj|2<}9WqHZY&UOMIfLQ)8GBEsO_|NeB|33|RIavl7Sy_gA4<0gb zaB_k*GchqS{QmQY;nkbB91k8n=6Lt9)`zHo-#;^i83fEC@}o^^@{kxw7l0vP{OQXVCKe7JhWB5-F|Yt_ zWn^My;N@Xu;N#|I_yx3$0~lq`o;?TK&I$~-r>|Zz{QUa)K0pAm{QB|r4lr6+|NQ;K z@aE+U1|CihhBu!-F}!{EjsX;1Ap9SQ+1OYaK7Rbnzz%ewh^R2bjT_hhvN18<0|+3N zA3wf6{r&sz{~tepFn;{_f#LVh9}Il_{9q@7(g!001bhcZ<=;Pl8D719!=SFF#&G=T zv2QP5JbwTXKrA2LzkBiT-~YeBxMukeRQTZD9R?{G8HRuVfe8haLK&e(06G8u{bhLZ z;swKxFCQ7cfBX94$B!TH0Ro8S(}(wu7@3%V0{zJXioUl%|Ni;)lYxz$9T-(CK&P{V z5*^UM|6s2$0mJ9Y`3DRyo;|wCN3<0VHJ0IkK zMrc$5lR5)Xo`I8#3uqt{!{5Ju?t>f#5I`)VA|ed;?%qoQ`niqi&u=@RskT49|FC3Y zVpIm&#tbqLqygj=MkYpvAK$+*Fo8YC@DM}*1Q5&LzkfkAh`9a#-~ZeH{{Nc`(); var profiles = _qualityProvider.GetAllProfiles(); @@ -109,15 +114,25 @@ namespace NzbDrone.Web.Controllers [HttpPost] public JsonResult AddNewSeries(string rootPath, string seriesName, int seriesId, int qualityProfileId) { - var path = rootPath.Replace('|', Path.DirectorySeparatorChar).Replace('^', Path.VolumeSeparatorChar).Replace('`', '\'') + - Path.DirectorySeparatorChar + EpisodeRenameHelper.CleanFilename(seriesName); + try + { + var path = + rootPath.Replace('|', Path.DirectorySeparatorChar).Replace('^', Path.VolumeSeparatorChar).Replace( + '`', '\'') + + Path.DirectorySeparatorChar + EpisodeRenameHelper.CleanFilename(seriesName); - //Create the folder for the new series and then Add it - _diskProvider.CreateDirectory(path); + //Create the folder for the new series and then Add it + _diskProvider.CreateDirectory(path); - _seriesProvider.AddSeries(path, seriesId, qualityProfileId); - ScanNewSeries(); - return new JsonResult { Data = "ok" }; + _seriesProvider.AddSeries(path, seriesId, qualityProfileId); + ScanNewSeries(); + return new JsonResult {Data = "ok"}; + } + + catch(Exception ex) + { + return new JsonResult { Data = "failed" }; + } } public JsonResult AddSeries(string path, int seriesId, int qualityProfileId) @@ -157,5 +172,80 @@ namespace NzbDrone.Web.Controllers return new SelectList(dataVal, "Id", "SeriesName", selectId); } + + [HttpPost] + public JsonResult SaveRootDir(int id, string path) + { + try + { + _rootFolderProvider.Update(new RootDir { Id = id, Path = path }); + } + catch (Exception ex) + { + Logger.Debug("Failed to save Root Dir"); + Logger.DebugException(ex.Message, ex); + + return new JsonResult { Data = "failed" }; + } + + return new JsonResult { Data = "ok" }; + } + + public ViewResult AddRootDir() + { + var rootDir = new RootDir { Path = String.Empty }; + + var id = _rootFolderProvider.Add(rootDir); + rootDir.Id = id; + + ViewData["RootDirId"] = id; + + return View("RootDir", rootDir); + } + + public ActionResult GetRootDirView(RootDir rootDir) + { + ViewData["RootDirId"] = rootDir.Id; + + return PartialView("RootDir", rootDir); + } + + public JsonResult DeleteRootDir(int rootDirId) + { + try + { + _rootFolderProvider.Remove(rootDirId); + } + + catch (Exception) + { + return new JsonResult { Data = "failed" }; + } + + return new JsonResult { Data = "ok" }; + } + + public JsonResult JsonAutoCompletePath(string term) + { + var windowsSep = term.LastIndexOf('\\'); + + if (windowsSep > -1) + { + var start = term.Substring(windowsSep + 1); + var dirs = _diskProvider.GetDirectories(term.Substring(0, windowsSep + 1)).Where(d => new DirectoryInfo(d).Name.ToLower().StartsWith(start.ToLower())).Take(10); + return Json(dirs.ToArray(), JsonRequestBehavior.AllowGet); + } + + var index = term.LastIndexOf('/'); + + if (index > -1) + { + var start = term.Substring(index + 1); + var dirs = _diskProvider.GetDirectories(term.Substring(0, index + 1)).Where(d => new DirectoryInfo(d).Name.ToLower().StartsWith(start.ToLower())).Take(10); + return Json(dirs.ToArray(), JsonRequestBehavior.AllowGet); + } + + return Json(new JsonResult(), JsonRequestBehavior.AllowGet); + } } } \ No newline at end of file diff --git a/NzbDrone.Web/Controllers/SettingsController.cs b/NzbDrone.Web/Controllers/SettingsController.cs index b88d81708..1a00d24d9 100644 --- a/NzbDrone.Web/Controllers/SettingsController.cs +++ b/NzbDrone.Web/Controllers/SettingsController.cs @@ -62,21 +62,11 @@ namespace NzbDrone.Web.Controllers ViewData["viewName"] = viewName; else - return RedirectToAction("General"); + return RedirectToAction("Indexers"); return View("Index"); } - public ActionResult General() - { - ViewData["viewName"] = "General"; - - return View("Index", new SettingsModel - { - Directories = _rootDirProvider.GetAll() - }); - } - public ActionResult Indexers() { ViewData["viewName"] = "Indexers"; @@ -236,40 +226,6 @@ namespace NzbDrone.Web.Controllers return PartialView("QualityProfileItem", profile); } - public ViewResult AddRootDir() - { - var rootDir = new RootDir { Path = String.Empty }; - - var id = _rootDirProvider.Add(rootDir); - rootDir.Id = id; - - ViewData["RootDirId"] = id; - - return View("RootDir", rootDir); - } - - public ActionResult GetRootDirView(RootDir rootDir) - { - ViewData["RootDirId"] = rootDir.Id; - - return PartialView("RootDir", rootDir); - } - - public JsonResult DeleteRootDir(int rootDirId) - { - try - { - _rootDirProvider.Remove(rootDirId); - } - - catch (Exception) - { - return new JsonResult { Data = "failed" }; - } - - return new JsonResult { Data = "ok" }; - } - public ActionResult SubMenu() { return PartialView(); @@ -317,29 +273,6 @@ namespace NzbDrone.Web.Controllers } } - public JsonResult JsonAutoCompletePath(string term) - { - var windowsSep = term.LastIndexOf('\\'); - - if (windowsSep > -1) - { - var start = term.Substring(windowsSep + 1); - var dirs = _diskProvider.GetDirectories(term.Substring(0, windowsSep + 1)).Where(d => new DirectoryInfo(d).Name.ToLower().StartsWith(start.ToLower())).Take(10); - return Json(dirs.ToArray(), JsonRequestBehavior.AllowGet); - } - - var index = term.LastIndexOf('/'); - - if (index > -1) - { - var start = term.Substring(index + 1); - var dirs = _diskProvider.GetDirectories(term.Substring(0, index + 1)).Where(d => new DirectoryInfo(d).Name.ToLower().StartsWith(start.ToLower())).Take(10); - return Json(dirs.ToArray(), JsonRequestBehavior.AllowGet); - } - - return Json(new JsonResult(), JsonRequestBehavior.AllowGet); - } - [HttpPost] public ActionResult SaveGeneral(SettingsModel data) { diff --git a/NzbDrone.Web/NzbDrone.Web.csproj b/NzbDrone.Web/NzbDrone.Web.csproj index a75cebce3..130169841 100644 --- a/NzbDrone.Web/NzbDrone.Web.csproj +++ b/NzbDrone.Web/NzbDrone.Web.csproj @@ -696,10 +696,9 @@ - - + diff --git a/NzbDrone.Web/Views/AddSeries/Add.cshtml b/NzbDrone.Web/Views/AddSeries/Add.cshtml index 87933d52a..8c104f3df 100644 --- a/NzbDrone.Web/Views/AddSeries/Add.cshtml +++ b/NzbDrone.Web/Views/AddSeries/Add.cshtml @@ -1,7 +1,18 @@ @model IEnumerable +@using NzbDrone.Core.Repository + + @section TitleContent{ Add Series } @@ -21,17 +32,47 @@ .LoadContentFrom("AddNew", "AddSeries") .Render(); } - - @if (Model.Count() == 0) + + @{ Html.Telerik().PanelBar() + .Name("RootDirPanel") + .HtmlAttributes(new { style = "margin: 0px;" }) + .ExpandMode(PanelBarExpandMode.Multiple) + .Items(panelItem => { - @Html.DisplayText("No Series to Add"); + panelItem.Add() + .Text("Root Directories") + .ImageUrl("~/Content/Images/VideoFolder.png") + .Content(@ +
+ + +
+ @foreach (var root in ViewData["RootDirs"] as List) + { + Html.RenderAction("GetRootDirView", root); + } +
+
+
); + }).Render(); } +
+ @Html.Telerik().DropDownList().Name("masterDropbox").BindTo((SelectList) ViewData["qualities"]).HtmlAttributes( new {style = "width: 100px; margin-left:5px;"}).ClientEvents(events => events.OnChange("masterChanged")) + @if (Model.Count() == 0) + { + @Html.DisplayText("No Series to Add"); + } + @foreach (var path in Model) { Html.RenderAction("RenderPartial", "AddSeries", new {path}); @@ -39,7 +80,6 @@ } \ No newline at end of file diff --git a/NzbDrone.Web/Views/AddSeries/AddNew.cshtml b/NzbDrone.Web/Views/AddSeries/AddNew.cshtml index b7f37b191..2a86e3913 100644 --- a/NzbDrone.Web/Views/AddSeries/AddNew.cshtml +++ b/NzbDrone.Web/Views/AddSeries/AddNew.cshtml @@ -53,14 +53,18 @@ url: addNewSeriesUrl, data: jQuery.param({ rootPath: rootPath, seriesName: seriesName, seriesId: id, qualityProfileId: quality }), error: function (req, status, error) { - alert("Sorry! We could not add " + path + " at this time. " + error); + alert("Sorry! We could not add " + seriesName + " at this time. " + error); }, - success: function (){ + success: function (data, textStatus, jqXHR){ //Clear the search box $("#seriesList_new").data("tComboBox").text(''); - //Close the Window! - closeAddNewSeries(); + //Through up an alert if we failed to add the series + if (data != 'ok') + alert("Sorry! We could not add " + seriesName + ", does it already exist?"); + + else + closeAddNewSeries(); //Close the Window! } }); } diff --git a/NzbDrone.Web/Views/AddSeries/AddSeriesItem.cshtml b/NzbDrone.Web/Views/AddSeries/AddSeriesItem.cshtml index 63f728966..32f84c960 100644 --- a/NzbDrone.Web/Views/AddSeries/AddSeriesItem.cshtml +++ b/NzbDrone.Web/Views/AddSeries/AddSeriesItem.cshtml @@ -5,39 +5,16 @@ @ViewData["path"].ToString()
@{Html.Telerik().ComboBox() - .Name("seriesList_" + ViewData["guid"].ToString()) + .Name("seriesList_" + ViewData["guid"]) .BindTo(Model) .DataBinding(binding => binding.Ajax().Select("_textLookUp", "AddSeries").Delay(400)) .Filterable(f => f.FilterMode(AutoCompleteFilterMode.Contains)) .HighlightFirstMatch(true) .HtmlAttributes(new { style = "width: 300px;" }) .Render();} - @Html.Telerik().DropDownList().Name("qualityList_" + ViewData["guid"].ToString()).BindTo((SelectList)ViewData["quality"]).HtmlAttributes(new { style = "width: 100px", @class = "qualityDropbox" }) + @Html.Telerik().DropDownList().Name("qualityList_" + ViewData["guid"]).BindTo((SelectList)ViewData["quality"]).HtmlAttributes(new { style = "width: 100px", @class = "qualityDropbox" })
- - + \ No newline at end of file diff --git a/NzbDrone.Web/Views/AddSeries/RootDir.cshtml b/NzbDrone.Web/Views/AddSeries/RootDir.cshtml new file mode 100644 index 000000000..465e73562 --- /dev/null +++ b/NzbDrone.Web/Views/AddSeries/RootDir.cshtml @@ -0,0 +1,16 @@ +@model NzbDrone.Core.Repository.RootDir + +@{ + Layout = null; +} + +
+
+ @Html.TextBoxFor(m => m.Path, new { @class = "root_dir_text", id = "path_" + Model.Id }) + + Delete + + + @Html.HiddenFor(x => x.Id, new { id = "id_" + Model.Id }) +
+
\ No newline at end of file diff --git a/NzbDrone.Web/Views/Settings/General.cshtml b/NzbDrone.Web/Views/Settings/General.cshtml deleted file mode 100644 index e24e8b1d9..000000000 --- a/NzbDrone.Web/Views/Settings/General.cshtml +++ /dev/null @@ -1,88 +0,0 @@ -@model NzbDrone.Web.Models.SettingsModel - - - -@using (Html.BeginForm("SaveGeneral", "Settings", FormMethod.Post, new {id = "form", name = "form"})) -{ -@Html.ValidationSummary(true, "Unable to save your settings. Please correct the errors and try again."); -
- General - -
- - -
- @foreach (var item in Model.Directories) - { - Html.RenderAction("GetRootDirView", item); - } -
-
- - -
-} -
- - \ No newline at end of file diff --git a/NzbDrone.Web/Views/Settings/Indexers.cshtml b/NzbDrone.Web/Views/Settings/Indexers.cshtml index 865fef4a6..cc47e0cf3 100644 --- a/NzbDrone.Web/Views/Settings/Indexers.cshtml +++ b/NzbDrone.Web/Views/Settings/Indexers.cshtml @@ -63,140 +63,139 @@ .HtmlAttributes(new { style = "width: 300px; margin: 10px;" }) .ExpandMode(PanelBarExpandMode.Single) .SelectedIndex(0) - .Items(item => + .Items(indexerItem => { - item.Add() + indexerItem.Add() .Text("NZBs.org") .ImageUrl("~/Content/Images/Indexers/NzbsOrg.png") - .Content( - "
" + + .Content(@ +
+
+
+ Enabled +
+
+ @Html.CheckBoxFor(m => m.NzbsOrgEnabled, new { @class = "indexer_checkbox" }) +
+
- "
" + - "
" + - "Enabled" + - "
" + - "
" + - Html.CheckBoxFor(m => m.NzbsOrgEnabled, new { @class = "indexer_checkbox" }) + - "
" + - "
" + - - "
" + - "
" + - Html.LabelFor(m => m.NzbsOrgUId) + - "
" + - "
" + - Html.TextBoxFor(m => m.NzbsOrgUId) + - "
" + - "
" + - "
" + - "
" + - Html.LabelFor(m => m.NzbsOrgHash) + - "
" + - "
" + - Html.TextBoxFor(m => m.NzbsOrgHash) + - "
" + - "
" + - "
" - ); - item.Add() +
+
+ @Html.LabelFor(m => m.NzbsOrgUId) +
+
+ @Html.TextBoxFor(m => m.NzbsOrgUId) +
+
+
+
+ @Html.LabelFor(m => m.NzbsOrgHash) +
+
+ @Html.TextBoxFor(m => m.NzbsOrgHash) +
+
+
+ ); + indexerItem.Add() .Text("NZB Matrix") .ImageUrl("~/Content/Images/Indexers/NzbMatrix.png") - .Content( - "
" + + .Content(@ +
- "
" + - "
" + - "Enabled" + - "
" + - "
" + - Html.CheckBoxFor(m => m.NzbMatrixEnabled, new { @class = "indexer_checkbox" }) + - "
" + - "
" + +
+
+ Enabled +
+
+ @Html.CheckBoxFor(m => m.NzbMatrixEnabled, new { @class = "indexer_checkbox" }) +
+
- "
" + - "
" + - Html.LabelFor(m => m.NzbMatrixUsername) + - "
" + - "
" + - Html.TextBoxFor(m => m.NzbMatrixUsername) + - "
" + - "
" + - "
" + - "
" + - Html.LabelFor(m => m.NzbMatrixApiKey) + - "
" + - "
" + - Html.TextBoxFor(m => m.NzbMatrixApiKey) + - "
" + - "
" + - "
" - ); - item.Add() +
+
+ @Html.LabelFor(m => m.NzbMatrixUsername) +
+
+ @Html.TextBoxFor(m => m.NzbMatrixUsername) +
+
+
+
+ @Html.LabelFor(m => m.NzbMatrixApiKey) +
+
+ @Html.TextBoxFor(m => m.NzbMatrixApiKey) +
+
+
+ ); + indexerItem.Add() .Text("NZBsRus") .ImageUrl("~/Content/Images/Indexers/NzbsRus.png") - .Content( - "
" + + .Content(@ +
- "
" + - "
" + - "Enabled" + - "
" + - "
" + - Html.CheckBoxFor(m => m.NzbsRUsEnabled, new { @class = "indexer_checkbox" }) + - "
" + - "
" + +
+
+ Enabled +
+
+ @Html.CheckBoxFor(m => m.NzbsRUsEnabled, new { @class = "indexer_checkbox" }) +
+
- "
" + - "
" + - Html.LabelFor(m => m.NzbsrusUId) + - "
" + - "
" + - Html.TextBoxFor(m => m.NzbsrusUId) + - "
" + - "
" + - "
" + - "
" + - Html.LabelFor(m => m.NzbsrusHash) + - "
" + - "
" + - Html.TextBoxFor(m => m.NzbsrusHash) + - "
" + - "
" + - "
" - ); - item.Add() +
+
+ @Html.LabelFor(m => m.NzbsrusUId) +
+
+ @Html.TextBoxFor(m => m.NzbsrusUId) +
+
+
+
+ @Html.LabelFor(m => m.NzbsrusHash) +
+
+ @Html.TextBoxFor(m => m.NzbsrusHash) +
+
+
+ ); + indexerItem.Add() .Text("Newzbin") .ImageUrl("~/Content/Images/Indexers/Newzbin.png") - .Content( - "
" + + .Content(@ +
- "
" + - "
" + - "Enabled" + - "
" + - "
" + - Html.CheckBoxFor(m => m.NewzbinEnabled, new { @class = "indexer_checkbox" }) + - "
" + - "
" + +
+
+ Enabled +
+
+ @Html.CheckBoxFor(m => m.NewzbinEnabled, new { @class = "indexer_checkbox" }) +
+
- "
" + - "
" + - Html.LabelFor(m => m.NewzbinUsername) + - "
" + - "
" + - Html.TextBoxFor(m => m.NewzbinUsername) + - "
" + - "
" + - "
" + - "
" + - Html.LabelFor(m => m.NewzbinPassword) + - "
" + - "
" + - Html.TextBoxFor(m => m.NewzbinPassword) + - "
" + - "
" + - "
" - ); +
+
+ @Html.LabelFor(m => m.NewzbinUsername) +
+
+ @Html.TextBoxFor(m => m.NewzbinUsername) +
+
+
+
+ @Html.LabelFor(m => m.NewzbinPassword) +
+
+ @Html.TextBoxFor(m => m.NewzbinPassword) +
+
+
+ ); }).Render(); } diff --git a/NzbDrone.Web/Views/Settings/RootDir.cshtml b/NzbDrone.Web/Views/Settings/RootDir.cshtml deleted file mode 100644 index 65df3ab13..000000000 --- a/NzbDrone.Web/Views/Settings/RootDir.cshtml +++ /dev/null @@ -1,35 +0,0 @@ -@model NzbDrone.Core.Repository.RootDir -@using NzbDrone.Web.Helpers; - -@{ - Layout = null; -} - - - -@using (Html.BeginCollectionItem("Directories")) -{ - var idClean = ViewData.TemplateInfo.HtmlFieldPrefix.Replace('[', '_').Replace(']', '_'); - - -
-
-
- @Html.TextBoxFor(m => m.Path, new { @class = "root_dir_text" }) - - Delete -
-
- @Html.ValidationMessageFor(m => m.Path) -
-
- @Html.TextBoxFor(x => x.Id, new { @style = "display:none" }) -
-
-
-} \ No newline at end of file From cd4268cf4a421e7637ae9c5cc58fe3a75cca5783 Mon Sep 17 00:00:00 2001 From: Mark McDowall Date: Mon, 30 May 2011 23:46:24 -0700 Subject: [PATCH 2/3] Cleaned up AddSeries UI a bit. --- NzbDrone.Web/Views/AddSeries/Add.cshtml | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/NzbDrone.Web/Views/AddSeries/Add.cshtml b/NzbDrone.Web/Views/AddSeries/Add.cshtml index 8c104f3df..454046fd6 100644 --- a/NzbDrone.Web/Views/AddSeries/Add.cshtml +++ b/NzbDrone.Web/Views/AddSeries/Add.cshtml @@ -61,12 +61,13 @@ }).Render(); } -
+
+ - @Html.Telerik().DropDownList().Name("masterDropbox").BindTo((SelectList) ViewData["qualities"]).HtmlAttributes( - new {style = "width: 100px; margin-left:5px;"}).ClientEvents(events => events.OnChange("masterChanged")) + @Html.Telerik().DropDownList().Name("masterDropbox").BindTo((SelectList) ViewData["qualities"]).HtmlAttributes( + new {style = "width: 100px; margin-left:224px;"}).ClientEvents(events => events.OnChange("masterChanged")) - +
@if (Model.Count() == 0) { From 8d38f98338e322910fc53bfb952f7f70c8116fcb Mon Sep 17 00:00:00 2001 From: Mark McDowall Date: Tue, 31 May 2011 13:50:19 -0700 Subject: [PATCH 3/3] Add Existing with Refresh button after modifying root dirs. Renamed AddSeries/Add to AddSeries/Index --- NzbDrone.Web/Content/style.css | 5 +++++ .../Controllers/AddSeriesController.cs | 18 ++++++++++------ NzbDrone.Web/NzbDrone.Web.csproj | 5 ++++- .../Views/AddSeries/AddExisting.cshtml | 15 +++++++++++++ .../AddSeries/{Add.cshtml => Index.cshtml} | 21 +++++++++---------- NzbDrone.Web/Views/AddSeries/RootDir.cshtml | 2 +- NzbDrone.Web/Views/Series/SubMenu.cshtml | 2 +- 7 files changed, 48 insertions(+), 20 deletions(-) create mode 100644 NzbDrone.Web/Views/AddSeries/AddExisting.cshtml rename NzbDrone.Web/Views/AddSeries/{Add.cshtml => Index.cshtml} (91%) diff --git a/NzbDrone.Web/Content/style.css b/NzbDrone.Web/Content/style.css index 278830506..157a35e79 100644 --- a/NzbDrone.Web/Content/style.css +++ b/NzbDrone.Web/Content/style.css @@ -260,6 +260,11 @@ button, input[type="button"], input[type="submit"], input[type="reset"] margin: 10px; } +button:active, input[type="button"]:active, input[type="submit"]:active, input[type="reset"]:active +{ + border-color: #0C48B6; +} + .listButton { padding: 2px 10px 2px 10px; diff --git a/NzbDrone.Web/Controllers/AddSeriesController.cs b/NzbDrone.Web/Controllers/AddSeriesController.cs index 2573c1812..5d8018609 100644 --- a/NzbDrone.Web/Controllers/AddSeriesController.cs +++ b/NzbDrone.Web/Controllers/AddSeriesController.cs @@ -71,19 +71,25 @@ namespace NzbDrone.Web.Controllers return View(); } - public ActionResult Add() + public ActionResult Index() { - ViewData["RootDirs"] = _rootFolderProvider.GetAll(); - - var unmappedList = new List(); + var rootDirs = _rootFolderProvider.GetAll(); var profiles = _qualityProvider.GetAllProfiles(); var defaultQuality = Convert.ToInt32(_configProvider.DefaultQualityProfile); var selectList = new SelectList(profiles, "QualityProfileId", "Name", defaultQuality); - ViewData["qualities"] = selectList; - foreach (var folder in _rootFolderProvider.GetAll()) + return View(rootDirs); + } + + public ActionResult AddExisting() + { + var rootDirs = _rootFolderProvider.GetAll(); + + var unmappedList = new List(); + + foreach (var folder in rootDirs) { unmappedList.AddRange(_rootFolderProvider.GetUnmappedFolders(folder.Path)); } diff --git a/NzbDrone.Web/NzbDrone.Web.csproj b/NzbDrone.Web/NzbDrone.Web.csproj index 130169841..684ff37c3 100644 --- a/NzbDrone.Web/NzbDrone.Web.csproj +++ b/NzbDrone.Web/NzbDrone.Web.csproj @@ -664,7 +664,7 @@ - + @@ -871,6 +871,9 @@ + + +