ChildrenChangedEventArgs.cs 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. using System.Collections.Concurrent;
  2. using MediaBrowser.Controller.Entities;
  3. using System;
  4. using System.Collections.Generic;
  5. namespace MediaBrowser.Controller.Library
  6. {
  7. /// <summary>
  8. /// Class ChildrenChangedEventArgs
  9. /// </summary>
  10. public class ChildrenChangedEventArgs : EventArgs
  11. {
  12. /// <summary>
  13. /// Gets or sets the folder.
  14. /// </summary>
  15. /// <value>The folder.</value>
  16. public Folder Folder { get; set; }
  17. /// <summary>
  18. /// Gets or sets the items added.
  19. /// </summary>
  20. /// <value>The items added.</value>
  21. public ConcurrentBag<BaseItem> ItemsAdded { get; set; }
  22. /// <summary>
  23. /// Gets or sets the items removed.
  24. /// </summary>
  25. /// <value>The items removed.</value>
  26. public List<BaseItem> ItemsRemoved { get; set; }
  27. /// <summary>
  28. /// Gets or sets the items updated.
  29. /// </summary>
  30. /// <value>The items updated.</value>
  31. public ConcurrentBag<BaseItem> ItemsUpdated { get; set; }
  32. /// <summary>
  33. /// Create the args and set the folder property
  34. /// </summary>
  35. /// <param name="folder">The folder.</param>
  36. /// <exception cref="System.ArgumentNullException"></exception>
  37. public ChildrenChangedEventArgs(Folder folder)
  38. {
  39. if (folder == null)
  40. {
  41. throw new ArgumentNullException();
  42. }
  43. //init the folder property
  44. Folder = folder;
  45. //init the list
  46. ItemsAdded = new ConcurrentBag<BaseItem>();
  47. ItemsRemoved = new List<BaseItem>();
  48. ItemsUpdated = new ConcurrentBag<BaseItem>();
  49. }
  50. /// <summary>
  51. /// Adds the new item.
  52. /// </summary>
  53. /// <param name="item">The item.</param>
  54. /// <exception cref="System.ArgumentNullException"></exception>
  55. public void AddNewItem(BaseItem item)
  56. {
  57. if (item == null)
  58. {
  59. throw new ArgumentNullException();
  60. }
  61. ItemsAdded.Add(item);
  62. }
  63. /// <summary>
  64. /// Adds the updated item.
  65. /// </summary>
  66. /// <param name="item">The item.</param>
  67. /// <exception cref="System.ArgumentNullException"></exception>
  68. public void AddUpdatedItem(BaseItem item)
  69. {
  70. if (item == null)
  71. {
  72. throw new ArgumentNullException();
  73. }
  74. ItemsUpdated.Add(item);
  75. }
  76. /// <summary>
  77. /// Adds the removed item.
  78. /// </summary>
  79. /// <param name="item">The item.</param>
  80. /// <exception cref="System.ArgumentNullException"></exception>
  81. public void AddRemovedItem(BaseItem item)
  82. {
  83. if (item == null)
  84. {
  85. throw new ArgumentNullException();
  86. }
  87. ItemsRemoved.Add(item);
  88. }
  89. /// <summary>
  90. /// Lists the has change.
  91. /// </summary>
  92. /// <param name="list">The list.</param>
  93. /// <returns><c>true</c> if XXXX, <c>false</c> otherwise</returns>
  94. private bool ListHasChange(List<BaseItem> list)
  95. {
  96. return list != null && list.Count > 0;
  97. }
  98. /// <summary>
  99. /// Lists the has change.
  100. /// </summary>
  101. /// <param name="list">The list.</param>
  102. /// <returns><c>true</c> if XXXX, <c>false</c> otherwise</returns>
  103. private bool ListHasChange(ConcurrentBag<BaseItem> list)
  104. {
  105. return list != null && !list.IsEmpty;
  106. }
  107. /// <summary>
  108. /// Gets a value indicating whether this instance has change.
  109. /// </summary>
  110. /// <value><c>true</c> if this instance has change; otherwise, <c>false</c>.</value>
  111. public bool HasChange
  112. {
  113. get { return HasAddOrRemoveChange || ListHasChange(ItemsUpdated); }
  114. }
  115. /// <summary>
  116. /// Gets a value indicating whether this instance has add or remove change.
  117. /// </summary>
  118. /// <value><c>true</c> if this instance has add or remove change; otherwise, <c>false</c>.</value>
  119. public bool HasAddOrRemoveChange
  120. {
  121. get { return ListHasChange(ItemsAdded) || ListHasChange(ItemsRemoved); }
  122. }
  123. }
  124. }