aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Model/Sync
diff options
context:
space:
mode:
authorLuke Pulverenti <luke.pulverenti@gmail.com>2014-12-15 00:16:23 -0500
committerLuke Pulverenti <luke.pulverenti@gmail.com>2014-12-15 00:16:23 -0500
commite92e0365747c04f081be0efbb9afb78dc96aef9b (patch)
tree51a7d2c0647d491737ca0bf9b9b8b3a11e9ee313 /MediaBrowser.Model/Sync
parented31b883f4bf1884ee974171501e61f83c768379 (diff)
add new sync methods
Diffstat (limited to 'MediaBrowser.Model/Sync')
-rw-r--r--MediaBrowser.Model/Sync/SyncHelper.cs51
-rw-r--r--MediaBrowser.Model/Sync/SyncJob.cs5
-rw-r--r--MediaBrowser.Model/Sync/SyncJobRequest.cs5
-rw-r--r--MediaBrowser.Model/Sync/SyncOptions.cs11
4 files changed, 62 insertions, 10 deletions
diff --git a/MediaBrowser.Model/Sync/SyncHelper.cs b/MediaBrowser.Model/Sync/SyncHelper.cs
new file mode 100644
index 000000000..ac595b5ef
--- /dev/null
+++ b/MediaBrowser.Model/Sync/SyncHelper.cs
@@ -0,0 +1,51 @@
+using MediaBrowser.Model.Dto;
+using System.Collections.Generic;
+
+namespace MediaBrowser.Model.Sync
+{
+ public static class SyncHelper
+ {
+ public static List<SyncOptions> GetSyncOptions(List<BaseItemDto> items)
+ {
+ List<SyncOptions> options = new List<SyncOptions>();
+
+ if (items.Count > 1)
+ {
+ options.Add(SyncOptions.Name);
+ }
+
+ foreach (BaseItemDto item in items)
+ {
+ if (item.SupportsSync ?? false)
+ {
+ if (item.IsVideo)
+ {
+ options.Add(SyncOptions.Quality);
+ options.Add(SyncOptions.UnwatchedOnly);
+ break;
+ }
+ if (item.IsFolder && !item.IsMusicGenre && !item.IsArtist && !item.IsType("musicalbum") && !item.IsGameGenre)
+ {
+ options.Add(SyncOptions.Quality);
+ options.Add(SyncOptions.UnwatchedOnly);
+ break;
+ }
+ }
+ }
+
+ foreach (BaseItemDto item in items)
+ {
+ if (item.SupportsSync ?? false)
+ {
+ if (item.IsFolder || item.IsGameGenre || item.IsMusicGenre || item.IsGenre || item.IsArtist || item.IsStudio || item.IsPerson)
+ {
+ options.Add(SyncOptions.SyncNewContent);
+ break;
+ }
+ }
+ }
+
+ return options;
+ }
+ }
+}
diff --git a/MediaBrowser.Model/Sync/SyncJob.cs b/MediaBrowser.Model/Sync/SyncJob.cs
index db67f3cbb..491223db5 100644
--- a/MediaBrowser.Model/Sync/SyncJob.cs
+++ b/MediaBrowser.Model/Sync/SyncJob.cs
@@ -46,11 +46,6 @@ namespace MediaBrowser.Model.Sync
/// <value><c>true</c> if [unwatched only]; otherwise, <c>false</c>.</value>
public bool UnwatchedOnly { get; set; }
/// <summary>
- /// Gets or sets a value indicating whether [remove when watched].
- /// </summary>
- /// <value><c>true</c> if [remove when watched]; otherwise, <c>false</c>.</value>
- public bool RemoveWhenWatched { get; set; }
- /// <summary>
/// Gets or sets a value indicating whether [synchronize new content].
/// </summary>
/// <value><c>true</c> if [synchronize new content]; otherwise, <c>false</c>.</value>
diff --git a/MediaBrowser.Model/Sync/SyncJobRequest.cs b/MediaBrowser.Model/Sync/SyncJobRequest.cs
index 4e044d62a..42a40acc7 100644
--- a/MediaBrowser.Model/Sync/SyncJobRequest.cs
+++ b/MediaBrowser.Model/Sync/SyncJobRequest.cs
@@ -35,11 +35,6 @@ namespace MediaBrowser.Model.Sync
/// <value><c>true</c> if [unwatched only]; otherwise, <c>false</c>.</value>
public bool UnwatchedOnly { get; set; }
/// <summary>
- /// Gets or sets a value indicating whether [remove when watched].
- /// </summary>
- /// <value><c>true</c> if [remove when watched]; otherwise, <c>false</c>.</value>
- public bool RemoveWhenWatched { get; set; }
- /// <summary>
/// Gets or sets a value indicating whether [synchronize new content].
/// </summary>
/// <value><c>true</c> if [synchronize new content]; otherwise, <c>false</c>.</value>
diff --git a/MediaBrowser.Model/Sync/SyncOptions.cs b/MediaBrowser.Model/Sync/SyncOptions.cs
new file mode 100644
index 000000000..edf22f799
--- /dev/null
+++ b/MediaBrowser.Model/Sync/SyncOptions.cs
@@ -0,0 +1,11 @@
+
+namespace MediaBrowser.Model.Sync
+{
+ public enum SyncOptions
+ {
+ Name = 0,
+ Quality = 1,
+ UnwatchedOnly = 2,
+ SyncNewContent
+ }
+}