JobMaterials.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Linq.Expressions;
  5. using System.Runtime.CompilerServices;
  6. using InABox.Core;
  7. using PRSClasses;
  8. namespace Comal.Classes
  9. {
  10. public class JobMaterialBOMAggregate : CoreAggregate<JobMaterial, JobBillOfMaterialsItem, double>
  11. {
  12. public override Expression<Func<JobBillOfMaterialsItem, double>> Aggregate => x => x.Quantity;
  13. public override AggregateCalculation Calculation => AggregateCalculation.Sum;
  14. public override Dictionary<Expression<Func<JobBillOfMaterialsItem, object>>, Expression<Func<JobMaterial, object>>> Links =>
  15. new Dictionary<Expression<Func<JobBillOfMaterialsItem, object>>, Expression<Func<JobMaterial, object>>>()
  16. {
  17. { JobBillOfMaterialsItem => JobBillOfMaterialsItem.Job.ID, JobMaterial => JobMaterial.Job.ID },
  18. { JobBillOfMaterialsItem => JobBillOfMaterialsItem.Product.ID, JobMaterial => JobMaterial.Product.ID },
  19. { JobBillOfMaterialsItem => JobBillOfMaterialsItem.Style.ID, JobMaterial => JobMaterial.Style.ID },
  20. { JobBillOfMaterialsItem => JobBillOfMaterialsItem.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }
  21. };
  22. public override Filter<JobBillOfMaterialsItem> Filter =>
  23. new Filter<JobBillOfMaterialsItem>(x => x.BillOfMaterials.Approved).IsNotEqualTo(DateTime.MinValue);
  24. }
  25. public class JobMaterialTotalRequiredAggregate : CoreAggregate<JobMaterial, JobRequisitionItem, double>
  26. {
  27. public override Expression<Func<JobRequisitionItem, double>> Aggregate => x => x.Qty;
  28. public override AggregateCalculation Calculation => AggregateCalculation.Sum;
  29. public override Dictionary<Expression<Func<JobRequisitionItem, object>>, Expression<Func<JobMaterial, object>>> Links =>
  30. new Dictionary<Expression<Func<JobRequisitionItem, object>>, Expression<Func<JobMaterial, object>>>()
  31. {
  32. { JobMaterialRequisitionItem => JobMaterialRequisitionItem.Requisition.Job.ID, JobMaterial => JobMaterial.Job.ID },
  33. { JobMaterialRequisitionItem => JobMaterialRequisitionItem.Product.ID, JobMaterial => JobMaterial.Product.ID },
  34. { JobMaterialRequisitionItem => JobMaterialRequisitionItem.Style.ID, JobMaterial => JobMaterial.Style.ID },
  35. { JobMaterialRequisitionItem => JobMaterialRequisitionItem.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }
  36. };
  37. public override Filter<JobRequisitionItem> Filter =>
  38. new Filter<JobRequisitionItem>(x => x.Requisition.Approved).IsNotEqualTo(DateTime.MinValue);
  39. }
  40. public class JobMaterialOrderAggregate : CoreAggregate<JobMaterial, PurchaseOrderItem, double>
  41. {
  42. public override Expression<Func<PurchaseOrderItem, double>> Aggregate => x => x.Qty;
  43. public override AggregateCalculation Calculation => AggregateCalculation.Sum;
  44. public override Dictionary<Expression<Func<PurchaseOrderItem, object>>, Expression<Func<JobMaterial, object>>> Links =>
  45. new Dictionary<Expression<Func<PurchaseOrderItem, object>>, Expression<Func<JobMaterial, object>>>()
  46. {
  47. { PurchaseOrderItem => PurchaseOrderItem.Job.ID, JobMaterial => JobMaterial.Job.ID },
  48. { PurchaseOrderItem => PurchaseOrderItem.Product.ID, JobMaterial => JobMaterial.Product.ID },
  49. { PurchaseOrderItem => PurchaseOrderItem.Style.ID, JobMaterial => JobMaterial.Style.ID },
  50. { PurchaseOrderItem => PurchaseOrderItem.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }
  51. };
  52. public override Filter<PurchaseOrderItem> Filter => new Filter<PurchaseOrderItem>(x => x.ReceivedDate).IsEqualTo(DateTime.MinValue);
  53. }
  54. public class JobMaterialOrderValue : CoreAggregate<JobMaterial, PurchaseOrderItem, double>
  55. {
  56. public override Expression<Func<PurchaseOrderItem, double>> Aggregate => x => x.ExTax;
  57. public override AggregateCalculation Calculation => AggregateCalculation.Sum;
  58. public override Dictionary<Expression<Func<PurchaseOrderItem, object>>, Expression<Func<JobMaterial, object>>> Links =>
  59. new Dictionary<Expression<Func<PurchaseOrderItem, object>>, Expression<Func<JobMaterial, object>>>()
  60. {
  61. { PurchaseOrderItem => PurchaseOrderItem.Job.ID, JobMaterial => JobMaterial.Job.ID },
  62. { PurchaseOrderItem => PurchaseOrderItem.Product.ID, JobMaterial => JobMaterial.Product.ID },
  63. { PurchaseOrderItem => PurchaseOrderItem.Style.ID, JobMaterial => JobMaterial.Style.ID },
  64. { PurchaseOrderItem => PurchaseOrderItem.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }
  65. };
  66. public override Filter<PurchaseOrderItem> Filter => new Filter<PurchaseOrderItem>(x => x.ReceivedDate).IsEqualTo(DateTime.MinValue);
  67. }
  68. public class JobMaterialReceivedAggregate : CoreAggregate<JobMaterial, StockMovement, double>
  69. {
  70. public override Expression<Func<StockMovement, double>> Aggregate => x => x.Received;
  71. public override Filter<StockMovement> Filter => new Filter<StockMovement>(x => x.IsTransfer).IsEqualTo(false);
  72. public override AggregateCalculation Calculation => AggregateCalculation.Sum;
  73. public override Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>> Links =>
  74. new Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>>()
  75. {
  76. { StockMovement => StockMovement.Job.ID, JobMaterial => JobMaterial.Job.ID },
  77. { StockMovement => StockMovement.Product.ID, JobMaterial => JobMaterial.Product.ID },
  78. { StockMovement => StockMovement.Style.ID, JobMaterial => JobMaterial.Style.ID },
  79. { StockMovement => StockMovement.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }
  80. };
  81. }
  82. public class JobMaterialIssuedAggregate : CoreAggregate<JobMaterial, StockMovement, double>
  83. {
  84. public override Expression<Func<StockMovement, double>> Aggregate => x => x.Issued;
  85. public override Filter<StockMovement> Filter => new Filter<StockMovement>(x => x.IsTransfer).IsEqualTo(false);
  86. public override AggregateCalculation Calculation => AggregateCalculation.Sum;
  87. public override Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>> Links =>
  88. new Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>>()
  89. {
  90. { StockMovement => StockMovement.Job.ID, JobMaterial => JobMaterial.Job.ID },
  91. { StockMovement => StockMovement.Product.ID, JobMaterial => JobMaterial.Product.ID },
  92. { StockMovement => StockMovement.Style.ID, JobMaterial => JobMaterial.Style.ID },
  93. { StockMovement => StockMovement.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }
  94. };
  95. }
  96. public class JobMaterialBalanceRequiredFormula : IFormula<JobMaterial, double>
  97. {
  98. public Expression<Func<JobMaterial, double>> Value => x => x.TotalRequired;
  99. public Expression<Func<JobMaterial, double>>[] Modifiers => new Expression<Func<JobMaterial, double>>[] { x => x.Issued, x=>x.ReservedStock, x=>x.OnOrder };
  100. public FormulaOperator Operator => FormulaOperator.Subtract;
  101. public FormulaType Type => FormulaType.Virtual;
  102. }
  103. public class JobMaterialReservedStockAggregate : CoreAggregate<JobMaterial, StockMovement, double>
  104. {
  105. public override Expression<Func<StockMovement, double>> Aggregate => x => x.Units;
  106. public override AggregateCalculation Calculation => AggregateCalculation.Sum;
  107. public override Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>> Links =>
  108. new Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>>()
  109. {
  110. { StockMovement => StockMovement.Job.ID, JobMaterial => JobMaterial.Job.ID },
  111. { StockMovement => StockMovement.Product.ID, JobMaterial => JobMaterial.Product.ID },
  112. { StockMovement => StockMovement.Style.ID, JobMaterial => JobMaterial.Style.ID },
  113. { StockMovement => StockMovement.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }
  114. };
  115. }
  116. public class JobMaterialFreeStockAggregate : CoreAggregate<JobMaterial, StockMovement, double>
  117. {
  118. public override Expression<Func<StockMovement, double>> Aggregate => x => x.Units;
  119. public override AggregateCalculation Calculation => AggregateCalculation.Sum;
  120. public override Filter<StockMovement> Filter => new Filter<StockMovement>(x => x.Job).NotLinkValid().Or(x=>x.Job.JobStatus.Active).IsEqualTo(false);
  121. public override Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>> Links =>
  122. new Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>>()
  123. {
  124. { StockMovement => StockMovement.Product.ID, JobMaterial => JobMaterial.Product.ID },
  125. //{ StockMovement => StockMovement.Style.ID, JobMaterial => JobMaterial.Style.ID },
  126. //{ StockMovement => StockMovement.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }
  127. };
  128. }
  129. public class JobMaterialUnionGenerator : AutoEntityUnionGenerator<IJobMaterial>
  130. {
  131. protected override void Configure()
  132. {
  133. AddTable<StockMovement>();
  134. AddTable<JobBillOfMaterialsItem>();
  135. AddTable<JobRequisitionItem>();
  136. AddTable<PurchaseOrderItem>();
  137. }
  138. public override bool Distinct => true;
  139. public override Column<IJobMaterial>[] IDColumns => new Column<IJobMaterial>[]
  140. {
  141. new Column<IJobMaterial>(x => x.Job.ID),
  142. new Column<IJobMaterial>(x => x.Product.ID),
  143. new Column<IJobMaterial>(x => x.Style.ID),
  144. new Column<IJobMaterial>(x => x.Dimensions.Unit.ID),
  145. new Column<IJobMaterial>(x => x.Dimensions.Quantity),
  146. new Column<IJobMaterial>(x => x.Dimensions.Length),
  147. new Column<IJobMaterial>(x => x.Dimensions.Width),
  148. new Column<IJobMaterial>(x => x.Dimensions.Height),
  149. new Column<IJobMaterial>(x => x.Dimensions.Weight)
  150. };
  151. }
  152. [UserTracking(typeof(Job))]
  153. [AutoEntity(typeof(JobMaterialUnionGenerator))]
  154. public class JobMaterial : StockEntity, IJobMaterial, IJobMaterialSummary, IRemotable, IPersistent, IManyToMany<Job, Product>, ILicense<ProjectManagementLicense> /* , IDimensioned */
  155. {
  156. [NullEditor]
  157. public JobLink Job { get; set; }
  158. [EditorSequence(1)]
  159. public override ProductLink Product { get; set; }
  160. [EditorSequence(2)]
  161. public ProductStyleLink Style { get; set; }
  162. [NullEditor]
  163. [Obsolete("Replaced with Dimensions", true)]
  164. public double UnitSize { get; set; }
  165. [EditorSequence(3)]
  166. [RequiredColumn]
  167. [DimensionsEditor(typeof(StockDimensions), AllowEditingUnit = false)]
  168. public override StockDimensions Dimensions { get; set; }
  169. [EditorSequence(4)]
  170. [DoubleEditor]
  171. [Aggregate(typeof(JobMaterialBOMAggregate))]
  172. public double BillOfMaterials { get; set; }
  173. [EditorSequence(5)]
  174. [DoubleEditor]
  175. [Aggregate(typeof(JobMaterialTotalRequiredAggregate))]
  176. public double TotalRequired { get; set; }
  177. [EditorSequence(6)]
  178. [DoubleEditor]
  179. [Aggregate(typeof(JobMaterialOrderAggregate))]
  180. public double OnOrder { get; set; }
  181. [EditorSequence(7)]
  182. [DoubleEditor]
  183. [Aggregate(typeof(JobMaterialOrderValue))]
  184. public double OrderValue { get; set; }
  185. [EditorSequence(8)]
  186. [Aggregate(typeof(JobMaterialReceivedAggregate))]
  187. [DoubleEditor(Editable = Editable.Hidden)]
  188. public double Received { get; set; }
  189. [EditorSequence(9)]
  190. [Aggregate(typeof(JobMaterialIssuedAggregate))]
  191. [DoubleEditor(Editable = Editable.Hidden)]
  192. public double Issued { get; set; }
  193. [EditorSequence(10)]
  194. [DoubleEditor]
  195. [Formula(typeof(JobMaterialBalanceRequiredFormula))]
  196. public double BalanceRequired { get; set; }
  197. [EditorSequence(11)]
  198. [Aggregate(typeof(JobMaterialReservedStockAggregate))]
  199. [DoubleEditor(Editable = Editable.Hidden)]
  200. public double ReservedStock { get; set; }
  201. [EditorSequence(12)]
  202. [Aggregate(typeof(JobMaterialFreeStockAggregate))]
  203. [DoubleEditor(Editable = Editable.Hidden)]
  204. public double FreeStock { get; set; }
  205. protected override void Init()
  206. {
  207. base.Init();
  208. Job = new JobLink();
  209. Style = new ProductStyleLink();
  210. }
  211. }
  212. }