| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265 | using System;using System.Collections.Generic;using System.Linq;using System.Linq.Expressions;using System.Runtime.CompilerServices;using InABox.Core;using PRSClasses;namespace Comal.Classes{    public class JobMaterialBOMAggregate : CoreAggregate<JobMaterial, JobBillOfMaterialsItem, double>    {        public override Expression<Func<JobBillOfMaterialsItem, double>> Aggregate => x => x.Quantity;        public override AggregateCalculation Calculation => AggregateCalculation.Sum;        public override Dictionary<Expression<Func<JobBillOfMaterialsItem, object>>, Expression<Func<JobMaterial, object>>> Links =>            new Dictionary<Expression<Func<JobBillOfMaterialsItem, object>>, Expression<Func<JobMaterial, object>>>()            {                { JobBillOfMaterialsItem => JobBillOfMaterialsItem.Job.ID, JobMaterial => JobMaterial.Job.ID },                { JobBillOfMaterialsItem => JobBillOfMaterialsItem.Product.ID, JobMaterial => JobMaterial.Product.ID },                { JobBillOfMaterialsItem => JobBillOfMaterialsItem.Style.ID, JobMaterial => JobMaterial.Style.ID },                { JobBillOfMaterialsItem => JobBillOfMaterialsItem.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }            };        public override Filter<JobBillOfMaterialsItem> Filter =>            new Filter<JobBillOfMaterialsItem>(x => x.BillOfMaterials.Approved).IsNotEqualTo(DateTime.MinValue);    }    public class JobMaterialTotalRequiredAggregate : CoreAggregate<JobMaterial, JobRequisitionItem, double>    {        public override Expression<Func<JobRequisitionItem, double>> Aggregate => x => x.Qty;        public override AggregateCalculation Calculation => AggregateCalculation.Sum;        public override Dictionary<Expression<Func<JobRequisitionItem, object>>, Expression<Func<JobMaterial, object>>> Links =>            new Dictionary<Expression<Func<JobRequisitionItem, object>>, Expression<Func<JobMaterial, object>>>()            {                { JobMaterialRequisitionItem => JobMaterialRequisitionItem.Requisition.Job.ID, JobMaterial => JobMaterial.Job.ID },                { JobMaterialRequisitionItem => JobMaterialRequisitionItem.Product.ID, JobMaterial => JobMaterial.Product.ID },                { JobMaterialRequisitionItem => JobMaterialRequisitionItem.Style.ID, JobMaterial => JobMaterial.Style.ID },                { JobMaterialRequisitionItem => JobMaterialRequisitionItem.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }            };                public override Filter<JobRequisitionItem> Filter =>            new Filter<JobRequisitionItem>(x => x.Requisition.Approved).IsNotEqualTo(DateTime.MinValue);    }        public class JobMaterialOrderAggregate : CoreAggregate<JobMaterial, PurchaseOrderItem, double>    {        public override Expression<Func<PurchaseOrderItem, double>> Aggregate => x => x.Qty;        public override AggregateCalculation Calculation => AggregateCalculation.Sum;        public override Dictionary<Expression<Func<PurchaseOrderItem, object>>, Expression<Func<JobMaterial, object>>> Links =>            new Dictionary<Expression<Func<PurchaseOrderItem, object>>, Expression<Func<JobMaterial, object>>>()            {                { PurchaseOrderItem => PurchaseOrderItem.Job.ID, JobMaterial => JobMaterial.Job.ID },                { PurchaseOrderItem => PurchaseOrderItem.Product.ID, JobMaterial => JobMaterial.Product.ID },                { PurchaseOrderItem => PurchaseOrderItem.Style.ID, JobMaterial => JobMaterial.Style.ID },                { PurchaseOrderItem => PurchaseOrderItem.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }            };        public override Filter<PurchaseOrderItem> Filter => new Filter<PurchaseOrderItem>(x => x.ReceivedDate).IsEqualTo(DateTime.MinValue);    }    public class JobMaterialOrderValue : CoreAggregate<JobMaterial, PurchaseOrderItem, double>    {        public override Expression<Func<PurchaseOrderItem, double>> Aggregate => x => x.ExTax;        public override AggregateCalculation Calculation => AggregateCalculation.Sum;        public override Dictionary<Expression<Func<PurchaseOrderItem, object>>, Expression<Func<JobMaterial, object>>> Links =>            new Dictionary<Expression<Func<PurchaseOrderItem, object>>, Expression<Func<JobMaterial, object>>>()            {                { PurchaseOrderItem => PurchaseOrderItem.Job.ID, JobMaterial => JobMaterial.Job.ID },                { PurchaseOrderItem => PurchaseOrderItem.Product.ID, JobMaterial => JobMaterial.Product.ID },                { PurchaseOrderItem => PurchaseOrderItem.Style.ID, JobMaterial => JobMaterial.Style.ID },                { PurchaseOrderItem => PurchaseOrderItem.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }            };        public override Filter<PurchaseOrderItem> Filter => new Filter<PurchaseOrderItem>(x => x.ReceivedDate).IsEqualTo(DateTime.MinValue);    }    public class JobMaterialReceivedAggregate : CoreAggregate<JobMaterial, StockMovement, double>    {        public override Expression<Func<StockMovement, double>> Aggregate => x => x.Received;        public override Filter<StockMovement> Filter => new Filter<StockMovement>(x => x.IsTransfer).IsEqualTo(false);        public override AggregateCalculation Calculation => AggregateCalculation.Sum;        public override Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>> Links =>            new Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>>()            {                { StockMovement => StockMovement.Job.ID, JobMaterial => JobMaterial.Job.ID },                { StockMovement => StockMovement.Product.ID, JobMaterial => JobMaterial.Product.ID },                { StockMovement => StockMovement.Style.ID, JobMaterial => JobMaterial.Style.ID },                { StockMovement => StockMovement.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }            };    }    public class JobMaterialIssuedAggregate : CoreAggregate<JobMaterial, StockMovement, double>    {        public override Expression<Func<StockMovement, double>> Aggregate => x => x.Issued;        public override Filter<StockMovement> Filter => new Filter<StockMovement>(x => x.IsTransfer).IsEqualTo(false);        public override AggregateCalculation Calculation => AggregateCalculation.Sum;        public override Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>> Links =>            new Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>>()            {                { StockMovement => StockMovement.Job.ID, JobMaterial => JobMaterial.Job.ID },                { StockMovement => StockMovement.Product.ID, JobMaterial => JobMaterial.Product.ID },                { StockMovement => StockMovement.Style.ID, JobMaterial => JobMaterial.Style.ID },                { StockMovement => StockMovement.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }            };    }    public class JobMaterialBalanceRequiredFormula : IFormula<JobMaterial, double>    {        public Expression<Func<JobMaterial, double>> Value => x => x.TotalRequired;        public Expression<Func<JobMaterial, double>>[] Modifiers => new Expression<Func<JobMaterial, double>>[] { x => x.Issued, x=>x.ReservedStock, x=>x.OnOrder };        public FormulaOperator Operator => FormulaOperator.Subtract;        public FormulaType Type => FormulaType.Virtual;    }    public class JobMaterialReservedStockAggregate : CoreAggregate<JobMaterial, StockMovement, double>    {        public override Expression<Func<StockMovement, double>> Aggregate => x => x.Units;        public override AggregateCalculation Calculation => AggregateCalculation.Sum;        public override Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>> Links =>            new Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>>()            {                { StockMovement => StockMovement.Job.ID, JobMaterial => JobMaterial.Job.ID },                { StockMovement => StockMovement.Product.ID, JobMaterial => JobMaterial.Product.ID },                { StockMovement => StockMovement.Style.ID, JobMaterial => JobMaterial.Style.ID },                { StockMovement => StockMovement.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }            };    }    public class JobMaterialFreeStockAggregate : CoreAggregate<JobMaterial, StockMovement, double>    {        public override Expression<Func<StockMovement, double>> Aggregate => x => x.Units;        public override AggregateCalculation Calculation => AggregateCalculation.Sum;        public override Filter<StockMovement> Filter => new Filter<StockMovement>(x => x.Job).NotLinkValid().Or(x=>x.Job.JobStatus.Active).IsEqualTo(false);        public override Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>> Links =>            new Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<JobMaterial, object>>>()            {                { StockMovement => StockMovement.Product.ID, JobMaterial => JobMaterial.Product.ID },                //{ StockMovement => StockMovement.Style.ID, JobMaterial => JobMaterial.Style.ID },                //{ StockMovement => StockMovement.Dimensions.UnitSize, JobMaterial => JobMaterial.Dimensions.UnitSize }            };    }    public class JobMaterialUnionGenerator : AutoEntityUnionGenerator<IJobMaterial>    {        protected override void Configure()        {            AddTable<StockMovement>();            AddTable<JobBillOfMaterialsItem>();            AddTable<JobRequisitionItem>();            AddTable<PurchaseOrderItem>();        }        public override bool Distinct => true;        public override Column<IJobMaterial>[] IDColumns => new Column<IJobMaterial>[]        {            new Column<IJobMaterial>(x => x.Job.ID),            new Column<IJobMaterial>(x => x.Product.ID),            new Column<IJobMaterial>(x => x.Style.ID),            new Column<IJobMaterial>(x => x.Dimensions.Unit.ID),            new Column<IJobMaterial>(x => x.Dimensions.Quantity),            new Column<IJobMaterial>(x => x.Dimensions.Length),            new Column<IJobMaterial>(x => x.Dimensions.Width),            new Column<IJobMaterial>(x => x.Dimensions.Height),            new Column<IJobMaterial>(x => x.Dimensions.Weight)        };    }        [UserTracking(typeof(Job))]    [AutoEntity(typeof(JobMaterialUnionGenerator))]    public class JobMaterial : StockEntity, IJobMaterial, IJobMaterialSummary, IRemotable, IPersistent, IManyToMany<Job, Product>, ILicense<ProjectManagementLicense> /* , IDimensioned */    {                [NullEditor]        public JobLink Job { get; set; }        [EditorSequence(1)]        public override ProductLink Product { get; set; }        [EditorSequence(2)]        public ProductStyleLink Style { get; set; }        [NullEditor]        [Obsolete("Replaced with Dimensions", true)]        public double UnitSize { get; set; }        [EditorSequence(3)]        [RequiredColumn]        [DimensionsEditor(typeof(StockDimensions), AllowEditingUnit = false)]        public override StockDimensions Dimensions { get; set; }                [EditorSequence(4)]        [DoubleEditor]        [Aggregate(typeof(JobMaterialBOMAggregate))]        public double BillOfMaterials { get; set; }        [EditorSequence(5)]        [DoubleEditor]        [Aggregate(typeof(JobMaterialTotalRequiredAggregate))]        public double TotalRequired { get; set; }        [EditorSequence(6)]        [DoubleEditor]        [Aggregate(typeof(JobMaterialOrderAggregate))]        public double OnOrder { get; set; }        [EditorSequence(7)]        [DoubleEditor]        [Aggregate(typeof(JobMaterialOrderValue))]        public double OrderValue { get; set; }        [EditorSequence(8)]        [Aggregate(typeof(JobMaterialReceivedAggregate))]        [DoubleEditor(Editable = Editable.Hidden)]        public double Received { get; set; }        [EditorSequence(9)]        [Aggregate(typeof(JobMaterialIssuedAggregate))]        [DoubleEditor(Editable = Editable.Hidden)]        public double Issued { get; set; }        [EditorSequence(10)]        [DoubleEditor]        [Formula(typeof(JobMaterialBalanceRequiredFormula))]        public double BalanceRequired { get; set; }        [EditorSequence(11)]        [Aggregate(typeof(JobMaterialReservedStockAggregate))]        [DoubleEditor(Editable = Editable.Hidden)]        public double ReservedStock { get; set; }        [EditorSequence(12)]        [Aggregate(typeof(JobMaterialFreeStockAggregate))]        [DoubleEditor(Editable = Editable.Hidden)]        public double FreeStock { get; set; }                protected override void Init()        {            base.Init();            Job = new JobLink();            Style = new ProductStyleLink();        }            }}
 |