From 210902ecb672c2bfd727c450806c9d5b2c295681 Mon Sep 17 00:00:00 2001 From: Qstick Date: Mon, 16 Apr 2018 18:22:54 -0400 Subject: [PATCH] Added: Setting for Colon Replacement Format (#2711) Fixes #2140 Fixes #2657 --- src/NzbDrone.Api/Config/NamingConfigModule.cs | 52 ----- .../Config/NamingConfigResource.cs | 9 +- .../UsenetDownloadStationFixture.cs | 17 +- .../OrganizerTests/CleanFixture.cs | 4 +- ..._naming_config_colon_replacement_format.cs | 14 ++ .../Clients/Blackhole/ScanWatchFolder.cs | 13 +- .../Clients/Blackhole/TorrentBlackhole.cs | 7 +- .../Clients/Blackhole/UsenetBlackhole.cs | 5 +- .../Download/Clients/Deluge/Deluge.cs | 4 +- .../DownloadStation/TorrentDownloadStation.cs | 4 +- .../DownloadStation/UsenetDownloadStation.cs | 4 +- .../Download/Clients/Hadouken/Hadouken.cs | 4 +- .../Download/Clients/NzbVortex/NzbVortex.cs | 4 +- .../Download/Clients/Nzbget/Nzbget.cs | 4 +- .../Download/Clients/Pneumatic/Pneumatic.cs | 7 +- .../Clients/QBittorrent/QBittorrent.cs | 4 +- .../Download/Clients/Sabnzbd/Sabnzbd.cs | 4 +- .../Clients/Transmission/Transmission.cs | 6 +- .../Clients/Transmission/TransmissionBase.cs | 4 +- .../Download/Clients/Vuze/Vuze.cs | 6 +- .../Download/Clients/rTorrent/RTorrent.cs | 4 +- .../Download/Clients/uTorrent/UTorrent.cs | 4 +- .../Download/DownloadClientBase.cs | 13 +- .../Download/TorrentClientBase.cs | 5 +- .../Download/UsenetClientBase.cs | 5 +- src/NzbDrone.Core/NzbDrone.Core.csproj | 3 +- .../Organizer/FileNameBuilder.cs | 18 +- src/NzbDrone.Core/Organizer/NamingConfig.cs | 32 +++ .../MediaManagement/Naming/NamingView.js | 41 ++-- .../Naming/NamingViewTemplate.hbs | 198 ++++-------------- 30 files changed, 213 insertions(+), 286 deletions(-) create mode 100644 src/NzbDrone.Core/Datastore/Migration/146_naming_config_colon_replacement_format.cs diff --git a/src/NzbDrone.Api/Config/NamingConfigModule.cs b/src/NzbDrone.Api/Config/NamingConfigModule.cs index 474bcae45..42efaa49a 100644 --- a/src/NzbDrone.Api/Config/NamingConfigModule.cs +++ b/src/NzbDrone.Api/Config/NamingConfigModule.cs @@ -34,11 +34,6 @@ namespace NzbDrone.Api.Config Get["/samples"] = x => GetExamples(this.Bind()); SharedValidator.RuleFor(c => c.MultiEpisodeStyle).InclusiveBetween(0, 5); - /*SharedValidator.RuleFor(c => c.StandardEpisodeFormat).ValidEpisodeFormat(); - SharedValidator.RuleFor(c => c.DailyEpisodeFormat).ValidDailyEpisodeFormat(); - SharedValidator.RuleFor(c => c.AnimeEpisodeFormat).ValidAnimeEpisodeFormat(); - SharedValidator.RuleFor(c => c.SeriesFolderFormat).ValidSeriesFolderFormat(); - SharedValidator.RuleFor(c => c.SeasonFolderFormat).ValidSeasonFolderFormat();*/ SharedValidator.RuleFor(c => c.StandardMovieFormat).ValidMovieFormat(); SharedValidator.RuleFor(c => c.MovieFolderFormat).ValidMovieFolderFormat(); } @@ -56,12 +51,6 @@ namespace NzbDrone.Api.Config var nameSpec = _namingConfigService.GetConfig(); var resource = nameSpec.ToResource(); - //if (resource.StandardEpisodeFormat.IsNotNullOrWhiteSpace()) - //{ - // var basicConfig = _filenameBuilder.GetBasicNamingConfig(nameSpec); - // basicConfig.AddToResource(resource); - //} - if (resource.StandardMovieFormat.IsNotNullOrWhiteSpace()) { var basicConfig = _filenameBuilder.GetBasicNamingConfig(nameSpec); @@ -80,48 +69,13 @@ namespace NzbDrone.Api.Config { var nameSpec = config.ToModel(); var sampleResource = new NamingSampleResource(); - - //var singleEpisodeSampleResult = _filenameSampleService.GetStandardSample(nameSpec); - //var multiEpisodeSampleResult = _filenameSampleService.GetMultiEpisodeSample(nameSpec); - //var dailyEpisodeSampleResult = _filenameSampleService.GetDailySample(nameSpec); - //var animeEpisodeSampleResult = _filenameSampleService.GetAnimeSample(nameSpec); - //var animeMultiEpisodeSampleResult = _filenameSampleService.GetAnimeMultiEpisodeSample(nameSpec); var movieSampleResult = _filenameSampleService.GetMovieSample(nameSpec); - - - //sampleResource.SingleEpisodeExample = _filenameValidationService.ValidateStandardFilename(singleEpisodeSampleResult) != null - // ? "Invalid format" - // : singleEpisodeSampleResult.FileName; - - //sampleResource.MultiEpisodeExample = _filenameValidationService.ValidateStandardFilename(multiEpisodeSampleResult) != null - // ? "Invalid format" - // : multiEpisodeSampleResult.FileName; - - //sampleResource.DailyEpisodeExample = _filenameValidationService.ValidateDailyFilename(dailyEpisodeSampleResult) != null - // ? "Invalid format" - // : dailyEpisodeSampleResult.FileName; - - //sampleResource.AnimeEpisodeExample = _filenameValidationService.ValidateAnimeFilename(animeEpisodeSampleResult) != null - // ? "Invalid format" - // : animeEpisodeSampleResult.FileName; - - //sampleResource.AnimeMultiEpisodeExample = _filenameValidationService.ValidateAnimeFilename(animeMultiEpisodeSampleResult) != null - // ? "Invalid format" - // : animeMultiEpisodeSampleResult.FileName; sampleResource.MovieExample = nameSpec.StandardMovieFormat.IsNullOrWhiteSpace() ? "Invalid Format" : movieSampleResult.FileName; - //sampleResource.SeriesFolderExample = nameSpec.SeriesFolderFormat.IsNullOrWhiteSpace() - // ? "Invalid format" - // : _filenameSampleService.GetSeriesFolderSample(nameSpec); - - //sampleResource.SeasonFolderExample = nameSpec.SeasonFolderFormat.IsNullOrWhiteSpace() - // ? "Invalid format" - // : _filenameSampleService.GetSeasonFolderSample(nameSpec); - sampleResource.MovieFolderExample = nameSpec.MovieFolderFormat.IsNullOrWhiteSpace() ? "Invalid format" : _filenameSampleService.GetMovieFolderSample(nameSpec); @@ -137,12 +91,6 @@ namespace NzbDrone.Api.Config var validationFailures = new List(); - //validationFailures.AddIfNotNull(singleEpisodeValidationResult); - //validationFailures.AddIfNotNull(multiEpisodeValidationResult); - //validationFailures.AddIfNotNull(dailyEpisodeValidationResult); - //validationFailures.AddIfNotNull(animeEpisodeValidationResult); - //validationFailures.AddIfNotNull(animeMultiEpisodeValidationResult); - //validationFailures.AddIfNotNull(standardMovieValidationResult); if (validationFailures.Any()) diff --git a/src/NzbDrone.Api/Config/NamingConfigResource.cs b/src/NzbDrone.Api/Config/NamingConfigResource.cs index e78395bbf..9e657e36e 100644 --- a/src/NzbDrone.Api/Config/NamingConfigResource.cs +++ b/src/NzbDrone.Api/Config/NamingConfigResource.cs @@ -7,6 +7,7 @@ namespace NzbDrone.Api.Config { public bool RenameEpisodes { get; set; } public bool ReplaceIllegalCharacters { get; set; } + public ColonReplacementFormat ColonReplacementFormat { get; set; } public string StandardMovieFormat { get; set; } public string MovieFolderFormat { get; set; } public int MultiEpisodeStyle { get; set; } @@ -28,6 +29,7 @@ namespace NzbDrone.Api.Config RenameEpisodes = model.RenameEpisodes, ReplaceIllegalCharacters = model.ReplaceIllegalCharacters, + ColonReplacementFormat = model.ColonReplacementFormat, MultiEpisodeStyle = model.MultiEpisodeStyle, StandardMovieFormat = model.StandardMovieFormat, MovieFolderFormat = model.MovieFolderFormat @@ -58,12 +60,7 @@ namespace NzbDrone.Api.Config RenameEpisodes = resource.RenameEpisodes, ReplaceIllegalCharacters = resource.ReplaceIllegalCharacters, - //MultiEpisodeStyle = resource.MultiEpisodeStyle, - //StandardEpisodeFormat = resource.StandardEpisodeFormat, - //DailyEpisodeFormat = resource.DailyEpisodeFormat, - //AnimeEpisodeFormat = resource.AnimeEpisodeFormat, - //SeriesFolderFormat = resource.SeriesFolderFormat, - //SeasonFolderFormat = resource.SeasonFolderFormat, + ColonReplacementFormat = resource.ColonReplacementFormat, StandardMovieFormat = resource.StandardMovieFormat, MovieFolderFormat = resource.MovieFolderFormat }; diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadStationTests/UsenetDownloadStationFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadStationTests/UsenetDownloadStationFixture.cs index fafdddaa7..26fd069bc 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadStationTests/UsenetDownloadStationFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadStationTests/UsenetDownloadStationFixture.cs @@ -1,4 +1,4 @@ -using System; +using System; using System.Collections.Generic; using System.Linq; using FluentAssertions; @@ -66,7 +66,7 @@ namespace NzbDrone.Core.Test.Download.DownloadClientTests.DownloadStationTests Detail = new Dictionary { { "destination","shared/folder" }, - { "uri", FileNameBuilder.CleanFileName(_remoteEpisode.Release.Title) + ".nzb" } + { "uri", CleanFileName(_remoteEpisode.Release.Title) } }, Transfer = new Dictionary { @@ -89,7 +89,7 @@ namespace NzbDrone.Core.Test.Download.DownloadClientTests.DownloadStationTests Detail = new Dictionary { { "destination","shared/folder" }, - { "uri", FileNameBuilder.CleanFileName(_remoteEpisode.Release.Title) + ".nzb" } + { "uri", CleanFileName(_remoteEpisode.Release.Title) } }, Transfer = new Dictionary { @@ -112,7 +112,7 @@ namespace NzbDrone.Core.Test.Download.DownloadClientTests.DownloadStationTests Detail = new Dictionary { { "destination","shared/folder" }, - { "uri", FileNameBuilder.CleanFileName(_remoteEpisode.Release.Title) + ".nzb" } + { "uri", CleanFileName(_remoteEpisode.Release.Title) } }, Transfer = new Dictionary { @@ -135,7 +135,7 @@ namespace NzbDrone.Core.Test.Download.DownloadClientTests.DownloadStationTests Detail = new Dictionary { { "destination","shared/folder" }, - { "uri", FileNameBuilder.CleanFileName(_remoteEpisode.Release.Title) + ".nzb" } + { "uri", CleanFileName(_remoteEpisode.Release.Title) } }, Transfer = new Dictionary { @@ -158,7 +158,7 @@ namespace NzbDrone.Core.Test.Download.DownloadClientTests.DownloadStationTests Detail = new Dictionary { { "destination","shared/folder" }, - { "uri", FileNameBuilder.CleanFileName(_remoteEpisode.Release.Title) + ".nzb" } + { "uri", CleanFileName(_remoteEpisode.Release.Title) } }, Transfer = new Dictionary { @@ -247,6 +247,11 @@ namespace NzbDrone.Core.Test.Download.DownloadClientTests.DownloadStationTests .Returns(tasks); } + protected static string CleanFileName(String name) + { + return FileNameBuilder.CleanFileName(name, NamingConfig.Default) + ".nzb"; + } + [Test] public void Download_with_TvDirectory_should_force_directory() { diff --git a/src/NzbDrone.Core.Test/OrganizerTests/CleanFixture.cs b/src/NzbDrone.Core.Test/OrganizerTests/CleanFixture.cs index e9746de0b..7e72d6ae2 100644 --- a/src/NzbDrone.Core.Test/OrganizerTests/CleanFixture.cs +++ b/src/NzbDrone.Core.Test/OrganizerTests/CleanFixture.cs @@ -12,8 +12,8 @@ namespace NzbDrone.Core.Test.OrganizerTests "Mission Impossible - no [HDTV-720p]")] public void CleanFileName(string name, string expectedName) { - FileNameBuilder.CleanFileName(name).Should().Be(expectedName); + FileNameBuilder.CleanFileName(name, NamingConfig.Default).Should().Be(expectedName); } } -} \ No newline at end of file +} diff --git a/src/NzbDrone.Core/Datastore/Migration/146_naming_config_colon_replacement_format.cs b/src/NzbDrone.Core/Datastore/Migration/146_naming_config_colon_replacement_format.cs new file mode 100644 index 000000000..3bbd64f52 --- /dev/null +++ b/src/NzbDrone.Core/Datastore/Migration/146_naming_config_colon_replacement_format.cs @@ -0,0 +1,14 @@ +using FluentMigrator; +using NzbDrone.Core.Datastore.Migration.Framework; + +namespace NzbDrone.Core.Datastore.Migration +{ + [Migration(146)] + public class naming_config_colon_action : NzbDroneMigrationBase + { + protected override void MainDbUpgrade() + { + Alter.Table("NamingConfig").AddColumn("ColonReplacementFormat").AsInt32().NotNullable().WithDefaultValue(0); + } + } +} diff --git a/src/NzbDrone.Core/Download/Clients/Blackhole/ScanWatchFolder.cs b/src/NzbDrone.Core/Download/Clients/Blackhole/ScanWatchFolder.cs index d6e80e3fd..78980c462 100644 --- a/src/NzbDrone.Core/Download/Clients/Blackhole/ScanWatchFolder.cs +++ b/src/NzbDrone.Core/Download/Clients/Blackhole/ScanWatchFolder.cs @@ -1,4 +1,4 @@ -using NLog; +using NLog; using NzbDrone.Common.Cache; using NzbDrone.Common.Crypto; using NzbDrone.Common.Disk; @@ -23,13 +23,15 @@ namespace NzbDrone.Core.Download.Clients.Blackhole private readonly Logger _logger; private readonly IDiskProvider _diskProvider; private readonly IDiskScanService _diskScanService; + private readonly INamingConfigService _namingConfigService; private readonly ICached> _watchFolderItemCache; - public ScanWatchFolder(ICacheManager cacheManager, IDiskScanService diskScanService, IDiskProvider diskProvider, Logger logger) + public ScanWatchFolder(ICacheManager cacheManager, IDiskScanService diskScanService, INamingConfigService namingConfigService, IDiskProvider diskProvider, Logger logger) { _logger = logger; _diskProvider = diskProvider; _diskScanService = diskScanService; + _namingConfigService = namingConfigService; _watchFolderItemCache = cacheManager.GetCache>(GetType()); } @@ -50,9 +52,12 @@ namespace NzbDrone.Core.Download.Clients.Blackhole private IEnumerable GetDownloadItems(string watchFolder, Dictionary lastWatchItems, TimeSpan waitPeriod) { + // get a fresh naming config each time, in case the user has made changes + NamingConfig namingConfig = _namingConfigService.GetConfig(); + foreach (var folder in _diskProvider.GetDirectories(watchFolder)) { - var title = FileNameBuilder.CleanFileName(Path.GetFileName(folder)); + var title = FileNameBuilder.CleanFileName(Path.GetFileName(folder), namingConfig); var newWatchItem = new WatchFolderItem { @@ -88,7 +93,7 @@ namespace NzbDrone.Core.Download.Clients.Blackhole foreach (var videoFile in _diskScanService.GetVideoFiles(watchFolder, false)) { - var title = FileNameBuilder.CleanFileName(Path.GetFileName(videoFile)); + var title = FileNameBuilder.CleanFileName(Path.GetFileName(videoFile), namingConfig); var newWatchItem = new WatchFolderItem { diff --git a/src/NzbDrone.Core/Download/Clients/Blackhole/TorrentBlackhole.cs b/src/NzbDrone.Core/Download/Clients/Blackhole/TorrentBlackhole.cs index d977d6ae5..c3a246f1e 100644 --- a/src/NzbDrone.Core/Download/Clients/Blackhole/TorrentBlackhole.cs +++ b/src/NzbDrone.Core/Download/Clients/Blackhole/TorrentBlackhole.cs @@ -28,10 +28,11 @@ namespace NzbDrone.Core.Download.Clients.Blackhole ITorrentFileInfoReader torrentFileInfoReader, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(torrentFileInfoReader, httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(torrentFileInfoReader, httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _scanWatchFolder = scanWatchFolder; @@ -47,7 +48,7 @@ namespace NzbDrone.Core.Download.Clients.Blackhole var title = remoteMovie.Release.Title; - title = FileNameBuilder.CleanFileName(title); + title = CleanFileName(title); var filepath = Path.Combine(Settings.TorrentFolder, string.Format("{0}.magnet", title)); @@ -66,7 +67,7 @@ namespace NzbDrone.Core.Download.Clients.Blackhole { var title = remoteMovie.Release.Title; - title = FileNameBuilder.CleanFileName(title); + title = CleanFileName(title); var filepath = Path.Combine(Settings.TorrentFolder, string.Format("{0}.torrent", title)); diff --git a/src/NzbDrone.Core/Download/Clients/Blackhole/UsenetBlackhole.cs b/src/NzbDrone.Core/Download/Clients/Blackhole/UsenetBlackhole.cs index ba0896787..47a46c527 100644 --- a/src/NzbDrone.Core/Download/Clients/Blackhole/UsenetBlackhole.cs +++ b/src/NzbDrone.Core/Download/Clients/Blackhole/UsenetBlackhole.cs @@ -22,10 +22,11 @@ namespace NzbDrone.Core.Download.Clients.Blackhole public UsenetBlackhole(IScanWatchFolder scanWatchFolder, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _scanWatchFolder = scanWatchFolder; @@ -36,7 +37,7 @@ namespace NzbDrone.Core.Download.Clients.Blackhole { var title = remoteMovie.Release.Title; - title = FileNameBuilder.CleanFileName(title); + title = CleanFileName(title); var filepath = Path.Combine(Settings.NzbFolder, title + ".nzb"); diff --git a/src/NzbDrone.Core/Download/Clients/Deluge/Deluge.cs b/src/NzbDrone.Core/Download/Clients/Deluge/Deluge.cs index 55b71345e..6c8185006 100644 --- a/src/NzbDrone.Core/Download/Clients/Deluge/Deluge.cs +++ b/src/NzbDrone.Core/Download/Clients/Deluge/Deluge.cs @@ -12,6 +12,7 @@ using NLog; using FluentValidation.Results; using System.Net; using NzbDrone.Core.RemotePathMappings; +using NzbDrone.Core.Organizer; namespace NzbDrone.Core.Download.Clients.Deluge { @@ -23,10 +24,11 @@ namespace NzbDrone.Core.Download.Clients.Deluge ITorrentFileInfoReader torrentFileInfoReader, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(torrentFileInfoReader, httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(torrentFileInfoReader, httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _proxy = proxy; } diff --git a/src/NzbDrone.Core/Download/Clients/DownloadStation/TorrentDownloadStation.cs b/src/NzbDrone.Core/Download/Clients/DownloadStation/TorrentDownloadStation.cs index 9f77add30..2d16f8b4d 100644 --- a/src/NzbDrone.Core/Download/Clients/DownloadStation/TorrentDownloadStation.cs +++ b/src/NzbDrone.Core/Download/Clients/DownloadStation/TorrentDownloadStation.cs @@ -11,6 +11,7 @@ using NzbDrone.Common.Http; using NzbDrone.Core.Configuration; using NzbDrone.Core.Download.Clients.DownloadStation.Proxies; using NzbDrone.Core.MediaFiles.TorrentInfo; +using NzbDrone.Core.Organizer; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.RemotePathMappings; using NzbDrone.Core.Validation; @@ -33,10 +34,11 @@ namespace NzbDrone.Core.Download.Clients.DownloadStation ITorrentFileInfoReader torrentFileInfoReader, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(torrentFileInfoReader, httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(torrentFileInfoReader, httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _dsInfoProxy = dsInfoProxy; _dsTaskProxy = dsTaskProxy; diff --git a/src/NzbDrone.Core/Download/Clients/DownloadStation/UsenetDownloadStation.cs b/src/NzbDrone.Core/Download/Clients/DownloadStation/UsenetDownloadStation.cs index 0f318f323..e8113a908 100644 --- a/src/NzbDrone.Core/Download/Clients/DownloadStation/UsenetDownloadStation.cs +++ b/src/NzbDrone.Core/Download/Clients/DownloadStation/UsenetDownloadStation.cs @@ -9,6 +9,7 @@ using NzbDrone.Common.Extensions; using NzbDrone.Common.Http; using NzbDrone.Core.Configuration; using NzbDrone.Core.Download.Clients.DownloadStation.Proxies; +using NzbDrone.Core.Organizer; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.RemotePathMappings; using NzbDrone.Core.Validation; @@ -30,11 +31,12 @@ namespace NzbDrone.Core.Download.Clients.DownloadStation IDownloadStationTaskProxy dsTaskProxy, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger ) - : base(httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _dsInfoProxy = dsInfoProxy; _dsTaskProxy = dsTaskProxy; diff --git a/src/NzbDrone.Core/Download/Clients/Hadouken/Hadouken.cs b/src/NzbDrone.Core/Download/Clients/Hadouken/Hadouken.cs index 1ef2a3f5f..47807958e 100644 --- a/src/NzbDrone.Core/Download/Clients/Hadouken/Hadouken.cs +++ b/src/NzbDrone.Core/Download/Clients/Hadouken/Hadouken.cs @@ -9,6 +9,7 @@ using NzbDrone.Common.Http; using NzbDrone.Core.Configuration; using NzbDrone.Core.Download.Clients.Hadouken.Models; using NzbDrone.Core.MediaFiles.TorrentInfo; +using NzbDrone.Core.Organizer; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.RemotePathMappings; using NzbDrone.Core.Validation; @@ -23,10 +24,11 @@ namespace NzbDrone.Core.Download.Clients.Hadouken ITorrentFileInfoReader torrentFileInfoReader, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(torrentFileInfoReader, httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(torrentFileInfoReader, httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _proxy = proxy; } diff --git a/src/NzbDrone.Core/Download/Clients/NzbVortex/NzbVortex.cs b/src/NzbDrone.Core/Download/Clients/NzbVortex/NzbVortex.cs index 1a5936933..330706b6b 100644 --- a/src/NzbDrone.Core/Download/Clients/NzbVortex/NzbVortex.cs +++ b/src/NzbDrone.Core/Download/Clients/NzbVortex/NzbVortex.cs @@ -11,6 +11,7 @@ using NzbDrone.Core.Configuration; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.Validation; using NzbDrone.Core.RemotePathMappings; +using NzbDrone.Core.Organizer; namespace NzbDrone.Core.Download.Clients.NzbVortex { @@ -21,10 +22,11 @@ namespace NzbDrone.Core.Download.Clients.NzbVortex public NzbVortex(INzbVortexProxy proxy, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _proxy = proxy; } diff --git a/src/NzbDrone.Core/Download/Clients/Nzbget/Nzbget.cs b/src/NzbDrone.Core/Download/Clients/Nzbget/Nzbget.cs index aa07d6519..beaabf241 100644 --- a/src/NzbDrone.Core/Download/Clients/Nzbget/Nzbget.cs +++ b/src/NzbDrone.Core/Download/Clients/Nzbget/Nzbget.cs @@ -11,6 +11,7 @@ using NzbDrone.Core.Configuration; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.Validation; using NzbDrone.Core.RemotePathMappings; +using NzbDrone.Core.Organizer; namespace NzbDrone.Core.Download.Clients.Nzbget { @@ -23,10 +24,11 @@ namespace NzbDrone.Core.Download.Clients.Nzbget public Nzbget(INzbgetProxy proxy, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _proxy = proxy; } diff --git a/src/NzbDrone.Core/Download/Clients/Pneumatic/Pneumatic.cs b/src/NzbDrone.Core/Download/Clients/Pneumatic/Pneumatic.cs index 1d38046b6..9bc7d98b5 100644 --- a/src/NzbDrone.Core/Download/Clients/Pneumatic/Pneumatic.cs +++ b/src/NzbDrone.Core/Download/Clients/Pneumatic/Pneumatic.cs @@ -20,10 +20,11 @@ namespace NzbDrone.Core.Download.Clients.Pneumatic public Pneumatic(IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(configService, diskProvider, remotePathMappingService, logger) + : base(configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _httpClient = httpClient; } @@ -43,7 +44,7 @@ namespace NzbDrone.Core.Download.Clients.Pneumatic // throw new NotSupportedException("Full season releases are not supported with Pneumatic."); //} - title = FileNameBuilder.CleanFileName(title); + title = CleanFileName(title); //Save to the Pneumatic directory (The user will need to ensure its accessible by XBMC) var nzbFile = Path.Combine(Settings.NzbFolder, title + ".nzb"); @@ -70,7 +71,7 @@ namespace NzbDrone.Core.Download.Clients.Pneumatic continue; } - var title = FileNameBuilder.CleanFileName(Path.GetFileName(file)); + var title = CleanFileName(Path.GetFileName(file)); var historyItem = new DownloadClientItem { diff --git a/src/NzbDrone.Core/Download/Clients/QBittorrent/QBittorrent.cs b/src/NzbDrone.Core/Download/Clients/QBittorrent/QBittorrent.cs index fd48381ef..07e248bef 100644 --- a/src/NzbDrone.Core/Download/Clients/QBittorrent/QBittorrent.cs +++ b/src/NzbDrone.Core/Download/Clients/QBittorrent/QBittorrent.cs @@ -12,6 +12,7 @@ using FluentValidation.Results; using System.Net; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.RemotePathMappings; +using NzbDrone.Core.Organizer; namespace NzbDrone.Core.Download.Clients.QBittorrent { @@ -23,10 +24,11 @@ namespace NzbDrone.Core.Download.Clients.QBittorrent ITorrentFileInfoReader torrentFileInfoReader, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(torrentFileInfoReader, httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(torrentFileInfoReader, httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _proxy = proxy; } diff --git a/src/NzbDrone.Core/Download/Clients/Sabnzbd/Sabnzbd.cs b/src/NzbDrone.Core/Download/Clients/Sabnzbd/Sabnzbd.cs index 898f5ba2f..f1fee1c68 100644 --- a/src/NzbDrone.Core/Download/Clients/Sabnzbd/Sabnzbd.cs +++ b/src/NzbDrone.Core/Download/Clients/Sabnzbd/Sabnzbd.cs @@ -11,6 +11,7 @@ using NzbDrone.Core.Configuration; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.Validation; using NzbDrone.Core.RemotePathMappings; +using NzbDrone.Core.Organizer; namespace NzbDrone.Core.Download.Clients.Sabnzbd { @@ -21,10 +22,11 @@ namespace NzbDrone.Core.Download.Clients.Sabnzbd public Sabnzbd(ISabnzbdProxy proxy, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _proxy = proxy; } diff --git a/src/NzbDrone.Core/Download/Clients/Transmission/Transmission.cs b/src/NzbDrone.Core/Download/Clients/Transmission/Transmission.cs index 058023d0c..3c2e25e36 100644 --- a/src/NzbDrone.Core/Download/Clients/Transmission/Transmission.cs +++ b/src/NzbDrone.Core/Download/Clients/Transmission/Transmission.cs @@ -1,4 +1,4 @@ -using System; +using System; using System.Text.RegularExpressions; using NzbDrone.Common.Disk; using NzbDrone.Common.Http; @@ -7,6 +7,7 @@ using NLog; using FluentValidation.Results; using NzbDrone.Core.MediaFiles.TorrentInfo; using NzbDrone.Core.RemotePathMappings; +using NzbDrone.Core.Organizer; namespace NzbDrone.Core.Download.Clients.Transmission { @@ -16,10 +17,11 @@ namespace NzbDrone.Core.Download.Clients.Transmission ITorrentFileInfoReader torrentFileInfoReader, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(proxy, torrentFileInfoReader, httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(proxy, torrentFileInfoReader, httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { } diff --git a/src/NzbDrone.Core/Download/Clients/Transmission/TransmissionBase.cs b/src/NzbDrone.Core/Download/Clients/Transmission/TransmissionBase.cs index 4098955ea..ecc53a1d4 100644 --- a/src/NzbDrone.Core/Download/Clients/Transmission/TransmissionBase.cs +++ b/src/NzbDrone.Core/Download/Clients/Transmission/TransmissionBase.cs @@ -9,6 +9,7 @@ using NzbDrone.Common.Extensions; using NzbDrone.Common.Http; using NzbDrone.Core.Configuration; using NzbDrone.Core.MediaFiles.TorrentInfo; +using NzbDrone.Core.Organizer; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.RemotePathMappings; using NzbDrone.Core.Validation; @@ -23,10 +24,11 @@ namespace NzbDrone.Core.Download.Clients.Transmission ITorrentFileInfoReader torrentFileInfoReader, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(torrentFileInfoReader, httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(torrentFileInfoReader, httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _proxy = proxy; } diff --git a/src/NzbDrone.Core/Download/Clients/Vuze/Vuze.cs b/src/NzbDrone.Core/Download/Clients/Vuze/Vuze.cs index dc3bb712e..3c0abba99 100644 --- a/src/NzbDrone.Core/Download/Clients/Vuze/Vuze.cs +++ b/src/NzbDrone.Core/Download/Clients/Vuze/Vuze.cs @@ -1,10 +1,11 @@ -using FluentValidation.Results; +using FluentValidation.Results; using NLog; using NzbDrone.Common.Disk; using NzbDrone.Common.Http; using NzbDrone.Core.Configuration; using NzbDrone.Core.Download.Clients.Transmission; using NzbDrone.Core.MediaFiles.TorrentInfo; +using NzbDrone.Core.Organizer; using NzbDrone.Core.RemotePathMappings; namespace NzbDrone.Core.Download.Clients.Vuze @@ -17,10 +18,11 @@ namespace NzbDrone.Core.Download.Clients.Vuze ITorrentFileInfoReader torrentFileInfoReader, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(proxy, torrentFileInfoReader, httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(proxy, torrentFileInfoReader, httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { } diff --git a/src/NzbDrone.Core/Download/Clients/rTorrent/RTorrent.cs b/src/NzbDrone.Core/Download/Clients/rTorrent/RTorrent.cs index ed43b89fd..3ea705dd2 100644 --- a/src/NzbDrone.Core/Download/Clients/rTorrent/RTorrent.cs +++ b/src/NzbDrone.Core/Download/Clients/rTorrent/RTorrent.cs @@ -15,6 +15,7 @@ using NzbDrone.Core.Exceptions; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.RemotePathMappings; using NzbDrone.Core.ThingiProvider; +using NzbDrone.Core.Organizer; namespace NzbDrone.Core.Download.Clients.RTorrent { @@ -27,11 +28,12 @@ namespace NzbDrone.Core.Download.Clients.RTorrent ITorrentFileInfoReader torrentFileInfoReader, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, IRTorrentDirectoryValidator rTorrentDirectoryValidator, Logger logger) - : base(torrentFileInfoReader, httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(torrentFileInfoReader, httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _proxy = proxy; _rTorrentDirectoryValidator = rTorrentDirectoryValidator; diff --git a/src/NzbDrone.Core/Download/Clients/uTorrent/UTorrent.cs b/src/NzbDrone.Core/Download/Clients/uTorrent/UTorrent.cs index d903a19f3..1994b2f10 100644 --- a/src/NzbDrone.Core/Download/Clients/uTorrent/UTorrent.cs +++ b/src/NzbDrone.Core/Download/Clients/uTorrent/UTorrent.cs @@ -13,6 +13,7 @@ using System.Net; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.RemotePathMappings; using NzbDrone.Common.Cache; +using NzbDrone.Core.Organizer; namespace NzbDrone.Core.Download.Clients.UTorrent { @@ -26,10 +27,11 @@ namespace NzbDrone.Core.Download.Clients.UTorrent ITorrentFileInfoReader torrentFileInfoReader, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(torrentFileInfoReader, httpClient, configService, diskProvider, remotePathMappingService, logger) + : base(torrentFileInfoReader, httpClient, configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _proxy = proxy; diff --git a/src/NzbDrone.Core/Download/DownloadClientBase.cs b/src/NzbDrone.Core/Download/DownloadClientBase.cs index 9db311c53..838ec6424 100644 --- a/src/NzbDrone.Core/Download/DownloadClientBase.cs +++ b/src/NzbDrone.Core/Download/DownloadClientBase.cs @@ -11,6 +11,7 @@ using NzbDrone.Core.Parser.Model; using NzbDrone.Core.RemotePathMappings; using NzbDrone.Core.ThingiProvider; using NzbDrone.Core.Validation; +using NzbDrone.Core.Organizer; namespace NzbDrone.Core.Download { @@ -18,6 +19,7 @@ namespace NzbDrone.Core.Download where TSettings : IProviderConfig, new() { protected readonly IConfigService _configService; + protected readonly INamingConfigService _namingConfigService; protected readonly IDiskProvider _diskProvider; protected readonly IRemotePathMappingService _remotePathMappingService; protected readonly Logger _logger; @@ -39,12 +41,14 @@ namespace NzbDrone.Core.Download protected TSettings Settings => (TSettings)Definition.Settings; - protected DownloadClientBase(IConfigService configService, + protected DownloadClientBase(IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) { _configService = configService; + _namingConfigService = namingConfigService; _diskProvider = diskProvider; _remotePathMappingService = remotePathMappingService; _logger = logger; @@ -151,6 +155,13 @@ namespace NzbDrone.Core.Download return null; } + // proxy method to pass in our naming config + protected String CleanFileName(string name) + { + // get a fresh naming config each time, in case the user has made changes + NamingConfig namingConfig = _namingConfigService.GetConfig(); + return FileNameBuilder.CleanFileName(name, namingConfig); + } } } diff --git a/src/NzbDrone.Core/Download/TorrentClientBase.cs b/src/NzbDrone.Core/Download/TorrentClientBase.cs index 52415d552..d5ca42926 100644 --- a/src/NzbDrone.Core/Download/TorrentClientBase.cs +++ b/src/NzbDrone.Core/Download/TorrentClientBase.cs @@ -25,10 +25,11 @@ namespace NzbDrone.Core.Download protected TorrentClientBase(ITorrentFileInfoReader torrentFileInfoReader, IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(configService, diskProvider, remotePathMappingService, logger) + : base(configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _httpClient = httpClient; _torrentFileInfoReader = torrentFileInfoReader; @@ -178,7 +179,7 @@ namespace NzbDrone.Core.Download throw new ReleaseDownloadException(remoteMovie.Release, "Downloading torrent failed", ex); } - var filename = string.Format("{0}.torrent", FileNameBuilder.CleanFileName(remoteMovie.Release.Title)); + var filename = string.Format("{0}.torrent", CleanFileName(remoteMovie.Release.Title)); var hash = _torrentFileInfoReader.GetHashFromTorrentFile(torrentFile); var actualHash = AddFromTorrentFile(remoteMovie, hash, filename, torrentFile); diff --git a/src/NzbDrone.Core/Download/UsenetClientBase.cs b/src/NzbDrone.Core/Download/UsenetClientBase.cs index 24b178d36..10df68a83 100644 --- a/src/NzbDrone.Core/Download/UsenetClientBase.cs +++ b/src/NzbDrone.Core/Download/UsenetClientBase.cs @@ -20,10 +20,11 @@ namespace NzbDrone.Core.Download protected UsenetClientBase(IHttpClient httpClient, IConfigService configService, + INamingConfigService namingConfigService, IDiskProvider diskProvider, IRemotePathMappingService remotePathMappingService, Logger logger) - : base(configService, diskProvider, remotePathMappingService, logger) + : base(configService, namingConfigService, diskProvider, remotePathMappingService, logger) { _httpClient = httpClient; } @@ -35,7 +36,7 @@ namespace NzbDrone.Core.Download public override string Download(RemoteMovie remoteMovie) { var url = remoteMovie.Release.DownloadUrl; - var filename = FileNameBuilder.CleanFileName(remoteMovie.Release.Title) + ".nzb"; + var filename = CleanFileName(remoteMovie.Release.Title) + ".nzb"; byte[] nzbData; diff --git a/src/NzbDrone.Core/NzbDrone.Core.csproj b/src/NzbDrone.Core/NzbDrone.Core.csproj index c2a8319e0..fe203847f 100644 --- a/src/NzbDrone.Core/NzbDrone.Core.csproj +++ b/src/NzbDrone.Core/NzbDrone.Core.csproj @@ -124,6 +124,7 @@ + @@ -1300,4 +1301,4 @@ --> - \ No newline at end of file + diff --git a/src/NzbDrone.Core/Organizer/FileNameBuilder.cs b/src/NzbDrone.Core/Organizer/FileNameBuilder.cs index 8bbdd639f..73cf999cd 100644 --- a/src/NzbDrone.Core/Organizer/FileNameBuilder.cs +++ b/src/NzbDrone.Core/Organizer/FileNameBuilder.cs @@ -248,8 +248,9 @@ namespace NzbDrone.Core.Organizer { AddMovieFileTokens(tokenHandlers, new MovieFile { SceneName = $"{movie.Title} {movie.Year}", RelativePath = $"{movie.Title} {movie.Year}"}); } - - return CleanFolderName(ReplaceTokens(namingConfig.MovieFolderFormat, tokenHandlers, namingConfig)); + + string name = ReplaceTokens(namingConfig.MovieFolderFormat, tokenHandlers, namingConfig); + return CleanFolderName(name, namingConfig); } public static string CleanTitle(string title) @@ -283,11 +284,14 @@ namespace NzbDrone.Core.Organizer return title.Trim(); } - public static string CleanFileName(string name, bool replace = true) + public static string CleanFileName(string name, NamingConfig namingConfig) { + bool replace = namingConfig.ReplaceIllegalCharacters; + var colonReplacementFormat = namingConfig.ColonReplacementFormat.GetFormatString(); + string result = name; string[] badCharacters = { "\\", "/", "<", ">", "?", "*", ":", "|", "\"" }; - string[] goodCharacters = { "+", "+", "", "", "!", "-", "", "", "" }; + string[] goodCharacters = { "+", "+", "", "", "!", "-", colonReplacementFormat, "", "" }; for (int i = 0; i < badCharacters.Length; i++) { @@ -297,12 +301,12 @@ namespace NzbDrone.Core.Organizer return result.Trim(); } - public static string CleanFolderName(string name) + public static string CleanFolderName(string name, NamingConfig namingConfig) { name = FileNameCleanupRegex.Replace(name, match => match.Captures[0].Value[0].ToString()); name = name.Trim(' ', '.'); - return CleanFileName(name); + return CleanFileName(name, namingConfig); } private void AddMovieTokens(Dictionary> tokenHandlers, Movie movie) @@ -557,7 +561,7 @@ namespace NzbDrone.Core.Organizer replacementText = replacementText.Replace(" ", tokenMatch.Separator); } - replacementText = CleanFileName(replacementText, namingConfig.ReplaceIllegalCharacters); + replacementText = CleanFileName(replacementText, namingConfig); if (!replacementText.IsNullOrWhiteSpace()) { diff --git a/src/NzbDrone.Core/Organizer/NamingConfig.cs b/src/NzbDrone.Core/Organizer/NamingConfig.cs index 5ce8324b2..51e40c550 100644 --- a/src/NzbDrone.Core/Organizer/NamingConfig.cs +++ b/src/NzbDrone.Core/Organizer/NamingConfig.cs @@ -1,3 +1,4 @@ +using System; using NzbDrone.Core.Datastore; namespace NzbDrone.Core.Organizer @@ -8,6 +9,7 @@ namespace NzbDrone.Core.Organizer { RenameEpisodes = false, ReplaceIllegalCharacters = true, + ColonReplacementFormat = 0, MultiEpisodeStyle = 0, MovieFolderFormat = "{Movie Title} ({Release Year})", StandardMovieFormat = "{Movie Title} ({Release Year}) {Quality Full}", @@ -15,8 +17,38 @@ namespace NzbDrone.Core.Organizer public bool RenameEpisodes { get; set; } public bool ReplaceIllegalCharacters { get; set; } + public ColonReplacementFormat ColonReplacementFormat { get; set; } public int MultiEpisodeStyle { get; set; } public string StandardMovieFormat { get; set; } public string MovieFolderFormat { get; set; } } + + public enum ColonReplacementFormat + { + Delete = 0, + Dash = 1, + SpaceDash = 2, + SpaceDashSpace = 3 + } + + static class ColonReplacementFormatMethods + { + + public static String GetFormatString(this ColonReplacementFormat format) + { + switch (format) + { + case ColonReplacementFormat.Delete: + return ""; + case ColonReplacementFormat.Dash: + return "-"; + case ColonReplacementFormat.SpaceDash: + return " -"; + case ColonReplacementFormat.SpaceDashSpace: + return " - "; + default: + return ""; + } + } + } } diff --git a/src/UI/Settings/MediaManagement/Naming/NamingView.js b/src/UI/Settings/MediaManagement/Naming/NamingView.js index 5496fb784..a8ab13056 100644 --- a/src/UI/Settings/MediaManagement/Naming/NamingView.js +++ b/src/UI/Settings/MediaManagement/Naming/NamingView.js @@ -11,29 +11,27 @@ module.exports = (function() { ui : { namingOptions : '.x-naming-options', renameEpisodesCheckbox : '.x-rename-episodes', - singleEpisodeExample : '.x-single-episode-example', - multiEpisodeExample : '.x-multi-episode-example', - dailyEpisodeExample : '.x-daily-episode-example', - animeEpisodeExample : '.x-anime-episode-example', - animeMultiEpisodeExample : '.x-anime-multi-episode-example', + replacingOptions : '.x-replacing-options', + replaceIllegalChars : '.x-replace-illegal-chars', namingTokenHelper : '.x-naming-token-helper', - multiEpisodeStyle : '.x-multi-episode-style', - seriesFolderExample : '.x-series-folder-example', - seasonFolderExample : '.x-season-folder-example', movieExample : '.x-movie-example', movieFolderExample : '.x-movie-folder-example' }, events : { - "change .x-rename-episodes" : '_setFailedDownloadOptionsVisibility', - "click .x-show-wizard" : '_showWizard', - "click .x-naming-token-helper a" : '_addToken', - "change .x-multi-episode-style" : '_multiEpisodeFomatChanged' + 'change .x-rename-episodes' : '_setRenameEpisodesVisibility', + 'change .x-replace-illegal-chars': '_setReplaceIllegalCharsVisibility', + 'click .x-show-wizard' : '_showWizard', + 'click .x-naming-token-helper a' : '_addToken', + 'change .x-multi-episode-style' : '_multiEpisodeFomatChanged' }, regions : { basicNamingRegion : '.x-basic-naming' }, onRender : function() { if (!this.model.get('renameEpisodes')) { this.ui.namingOptions.hide(); } + if (!this.model.get('replaceIllegalCharacters')) { + this.ui.replacingOptions.hide(); + } var basicNamingView = new BasicNamingView({ model : this.model }); this.basicNamingRegion.show(basicNamingView); this.namingSampleModel = new NamingSampleModel(); @@ -41,7 +39,7 @@ module.exports = (function() { this.listenTo(this.namingSampleModel, 'sync', this._showSamples); this._updateSamples(); }, - _setFailedDownloadOptionsVisibility : function() { + _setRenameEpisodesVisibility : function() { var checked = this.ui.renameEpisodesCheckbox.prop('checked'); if (checked) { this.ui.namingOptions.slideDown(); @@ -49,17 +47,18 @@ module.exports = (function() { this.ui.namingOptions.slideUp(); } }, + _setReplaceIllegalCharsVisibility : function() { + var checked = this.ui.replaceIllegalChars.prop('checked'); + if (checked) { + this.ui.replacingOptions.slideDown(); + } else { + this.ui.replacingOptions.slideUp(); + } + }, _updateSamples : function() { this.namingSampleModel.fetch({ data : this.model.toJSON() }); }, _showSamples : function() { - this.ui.singleEpisodeExample.html(this.namingSampleModel.get('singleEpisodeExample')); - this.ui.multiEpisodeExample.html(this.namingSampleModel.get('multiEpisodeExample')); - this.ui.dailyEpisodeExample.html(this.namingSampleModel.get('dailyEpisodeExample')); - this.ui.animeEpisodeExample.html(this.namingSampleModel.get('animeEpisodeExample')); - this.ui.animeMultiEpisodeExample.html(this.namingSampleModel.get('animeMultiEpisodeExample')); - this.ui.seriesFolderExample.html(this.namingSampleModel.get('seriesFolderExample')); - this.ui.seasonFolderExample.html(this.namingSampleModel.get('seasonFolderExample')); this.ui.movieExample.html(this.namingSampleModel.get('movieExample')); this.ui.movieFolderExample.html(this.namingSampleModel.get('movieFolderExample')); }, @@ -86,4 +85,4 @@ module.exports = (function() { AsModelBoundView.call(view); AsValidatedView.call(view); return view; -}).call(this); \ No newline at end of file +}).call(this); diff --git a/src/UI/Settings/MediaManagement/Naming/NamingViewTemplate.hbs b/src/UI/Settings/MediaManagement/Naming/NamingViewTemplate.hbs index 6ac568061..7f9afd2e3 100644 --- a/src/UI/Settings/MediaManagement/Naming/NamingViewTemplate.hbs +++ b/src/UI/Settings/MediaManagement/Naming/NamingViewTemplate.hbs @@ -24,126 +24,82 @@ -
- - -
-
-
-
-
- + -
- - -
+
+
+
- - {{!--
- - -
-

-
-
--}}