Update_8_23.cs 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. using System.Linq.Expressions;
  2. using Comal.Classes;
  3. using InABox.Configuration;
  4. using InABox.Core;
  5. using InABox.Database;
  6. using NPOI.SS.Formula.Functions;
  7. using Columns = InABox.Core.Columns;
  8. namespace PRS.Shared.Database_Update_Scripts;
  9. internal class Update_8_23 : DatabaseUpdateScript
  10. {
  11. public override VersionNumber Version => new(8, 23);
  12. public override bool Update()
  13. {
  14. var _provider = DbFactory.NewProvider(Logger.Main);
  15. CheckDimensions<RequisitionItem>(_provider);
  16. CheckDimensions<StockMovement>(_provider);
  17. var holdings = _provider.Query(
  18. null,
  19. Columns.None<StockHolding>()
  20. .Add(x => x.Location.ID)
  21. .Add(x => x.Product.ID)
  22. .Add(x => x.Job.ID)
  23. .Add(x => x.Style.ID)
  24. .Add(x => x.Dimensions.Unit.ID)
  25. .Add(x => x.Dimensions.Length)
  26. .Add(x => x.Dimensions.Width)
  27. .Add(x => x.Dimensions.Height)
  28. .Add(x => x.Dimensions.Quantity)
  29. .Add(x => x.Dimensions.Width)
  30. .Add(x => x.AverageValue)
  31. ).Rows.ToObjects<StockHolding>().ToArray();
  32. var instances = _provider.Query(
  33. null,
  34. Columns.None<ProductInstance>()
  35. .Add(x => x.Product.ID)
  36. .Add(x => x.Style.ID)
  37. .Add(x => x.Dimensions.Unit.ID)
  38. .Add(x => x.Dimensions.Length)
  39. .Add(x => x.Dimensions.Width)
  40. .Add(x => x.Dimensions.Height)
  41. .Add(x => x.Dimensions.Quantity)
  42. .Add(x => x.Dimensions.Width)
  43. .Add(x => x.AverageCost)
  44. ).Rows.ToObjects<ProductInstance>().ToArray();
  45. //CheckStockMovementCosts(_provider, holdings, instances);
  46. //RecalculateHoldings(_provider, holdings);
  47. return true;
  48. }
  49. // private void RecalculateHoldings(IProvider provider, StockHolding[] holdings)
  50. // {
  51. // foreach (var holding in holdings)
  52. // {
  53. // var movements = provider.Query(
  54. // new Filter<StockMovement>(x=>x.Product.ID))
  55. // }
  56. // }
  57. private void CheckStockMovementCosts(IProvider provider, StockHolding[] holdings, ProductInstance[] instances)
  58. {
  59. var items = provider.Query(
  60. new Filter<StockMovement>(x=>x.Product.ID).IsNotEqualTo(Guid.Empty).And(x=>x.Cost).IsEqualTo(0.0),
  61. Columns.None<StockMovement>()
  62. .Add(x => x.ID)
  63. .Add(x => x.Location.ID)
  64. .Add(x => x.Product.ID)
  65. .Add(x => x.Job.ID)
  66. .Add(x => x.Style.ID)
  67. .Add(x => x.Dimensions.Unit.ID)
  68. .Add(x => x.Dimensions.Length)
  69. .Add(x => x.Dimensions.Width)
  70. .Add(x => x.Dimensions.Height)
  71. .Add(x => x.Dimensions.Quantity)
  72. .Add(x => x.Dimensions.Width)
  73. .Add(x => x.Cost)
  74. ).Rows.ToQueue();
  75. while (items.Any())
  76. {
  77. Logger.Send(LogType.Information,"",$"Updating {nameof(StockMovement)} Costs ({items.Count} remaining)..");
  78. var updates = items.Dequeue(100).ToObjects<StockMovement>().ToArray();
  79. foreach (var item in updates)
  80. {
  81. var holding = holdings.FirstOrDefault(x =>
  82. Guid.Equals(x.Product.ID, item.Product.ID)
  83. && Guid.Equals(x.Location.ID, item.Location.ID)
  84. && Guid.Equals(x.Style.ID, item.Style.ID)
  85. && Guid.Equals(x.Dimensions.Unit.ID, item.Dimensions.Unit.ID)
  86. && x.Dimensions.Length.IsEffectivelyEqual(item.Dimensions.Length)
  87. && x.Dimensions.Width.IsEffectivelyEqual(item.Dimensions.Width)
  88. && x.Dimensions.Height.IsEffectivelyEqual(item.Dimensions.Height)
  89. && x.Dimensions.Weight.IsEffectivelyEqual(item.Dimensions.Weight)
  90. && x.Dimensions.Quantity.IsEffectivelyEqual(item.Dimensions.Quantity)
  91. );
  92. if (holding != null)
  93. item.Cost = holding.AverageValue;
  94. else
  95. {
  96. var instance = instances.FirstOrDefault(x =>
  97. Guid.Equals(x.Product.ID, item.Product.ID)
  98. && Guid.Equals(x.Style.ID, item.Style.ID)
  99. && Guid.Equals(x.Dimensions.Unit.ID, item.Dimensions.Unit.ID)
  100. && x.Dimensions.Length.IsEffectivelyEqual(item.Dimensions.Length)
  101. && x.Dimensions.Width.IsEffectivelyEqual(item.Dimensions.Width)
  102. && x.Dimensions.Height.IsEffectivelyEqual(item.Dimensions.Height)
  103. && x.Dimensions.Weight.IsEffectivelyEqual(item.Dimensions.Weight)
  104. && x.Dimensions.Quantity.IsEffectivelyEqual(item.Dimensions.Quantity)
  105. );
  106. if (instance != null)
  107. item.Cost = instance.AverageCost;
  108. }
  109. }
  110. provider.Save(updates.Where(x=>x.IsChanged()));
  111. }
  112. }
  113. private void CheckRequisitionItemCosts(IProvider provider, StockHolding[] holdings, ProductInstance[] instances)
  114. {
  115. var items = provider.Query(
  116. new Filter<RequisitionItem>(x=>x.Product.ID).IsNotEqualTo(Guid.Empty).And(x=>x.Cost).IsEqualTo(0.0),
  117. Columns.None<RequisitionItem>()
  118. .Add(x => x.ID)
  119. .Add(x => x.Location.ID)
  120. .Add(x => x.Product.ID)
  121. .Add(x => x.RequisitionLink.JobLink.ID)
  122. .Add(x => x.Style.ID)
  123. .Add(x => x.Dimensions.Unit.ID)
  124. .Add(x => x.Dimensions.Length)
  125. .Add(x => x.Dimensions.Width)
  126. .Add(x => x.Dimensions.Height)
  127. .Add(x => x.Dimensions.Quantity)
  128. .Add(x => x.Dimensions.Width)
  129. .Add(x => x.Cost)
  130. ).Rows.ToObjects<RequisitionItem>().ToQueue();
  131. while (items.Any())
  132. {
  133. Logger.Send(LogType.Information,"",$"Updating {nameof(RequisitionItem)} Costs ({items.Count} remaining)..");
  134. var updates = items.Dequeue(100).ToArray();
  135. foreach (var item in updates)
  136. {
  137. var holding = holdings.FirstOrDefault(x =>
  138. Guid.Equals(x.Product.ID, item.Product.ID)
  139. && Guid.Equals(x.Location.ID, item.Location.ID)
  140. && Guid.Equals(x.Style.ID, item.Style.ID)
  141. && Guid.Equals(x.Dimensions.Unit.ID, item.Dimensions.Unit.ID)
  142. && x.Dimensions.Length.IsEffectivelyEqual(item.Dimensions.Length)
  143. && x.Dimensions.Width.IsEffectivelyEqual(item.Dimensions.Width)
  144. && x.Dimensions.Height.IsEffectivelyEqual(item.Dimensions.Height)
  145. && x.Dimensions.Weight.IsEffectivelyEqual(item.Dimensions.Weight)
  146. && x.Dimensions.Quantity.IsEffectivelyEqual(item.Dimensions.Quantity)
  147. );
  148. if (holding != null)
  149. item.Cost = holding.AverageValue;
  150. else
  151. {
  152. var instance = instances.FirstOrDefault(x =>
  153. Guid.Equals(x.Product.ID, item.Product.ID)
  154. && Guid.Equals(x.Style.ID, item.Style.ID)
  155. && Guid.Equals(x.Dimensions.Unit.ID, item.Dimensions.Unit.ID)
  156. && x.Dimensions.Length.IsEffectivelyEqual(item.Dimensions.Length)
  157. && x.Dimensions.Width.IsEffectivelyEqual(item.Dimensions.Width)
  158. && x.Dimensions.Height.IsEffectivelyEqual(item.Dimensions.Height)
  159. && x.Dimensions.Weight.IsEffectivelyEqual(item.Dimensions.Weight)
  160. && x.Dimensions.Quantity.IsEffectivelyEqual(item.Dimensions.Quantity)
  161. );
  162. if (instance != null)
  163. item.Cost = instance.AverageCost;
  164. }
  165. }
  166. provider.Save(updates.Where(x=>x.IsChanged()));
  167. }
  168. }
  169. private void CheckDimensions<T>(IProvider provider) where T : StockEntity, new()
  170. {
  171. var items = provider.Query(
  172. new Filter<T>(x => x.Dimensions.Unit.ID).IsNotEqualTo(Guid.Empty).And(x=>x.Dimensions.Value).IsEqualTo(0.0),
  173. Columns.Required<T>()
  174. ).Rows.ToObjects<T>().ToQueue();
  175. while (items.Any())
  176. {
  177. Logger.Send(LogType.Information,"",$"Updating {typeof(T).Name.Split('.').Last()} Dimensions ({items.Count} remaining)..");
  178. var updates = items.Dequeue(100).ToArray();
  179. foreach (var item in updates)
  180. item.Dimensions.CalculateValueAndUnitSize();
  181. provider.Save(updates);
  182. }
  183. }
  184. }