| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240 | using System;using System.Collections.Generic;using System.Linq;using System.Linq.Expressions;using System.Runtime.CompilerServices;using InABox.Core;namespace Comal.Classes{    public class StockSummaryBOMAggregate : CoreAggregate<StockSummary, 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<StockSummary, object>>> Links =>            new Dictionary<Expression<Func<JobBillOfMaterialsItem, object>>, Expression<Func<StockSummary, object>>>()            {                { JobBillOfMaterialsItem => JobBillOfMaterialsItem.Job.ID, summary => summary.Job.ID },                { JobBillOfMaterialsItem => JobBillOfMaterialsItem.Product.ID, summary => summary.Product.ID },                { JobBillOfMaterialsItem => JobBillOfMaterialsItem.Style.ID, summary => summary.Style.ID },                { JobBillOfMaterialsItem => JobBillOfMaterialsItem.Dimensions.UnitSize, summary => summary.Dimensions.UnitSize }            };        public override Filter<JobBillOfMaterialsItem> Filter =>            new Filter<JobBillOfMaterialsItem>(x => x.BillOfMaterials.Approved).IsNotEqualTo(DateTime.MinValue);    }        public class StockSummaryIssuedAggregate : CoreAggregate<StockSummary, 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<StockSummary, object>>> Links =>            new Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<StockSummary, object>>>()            {                { StockMovement => StockMovement.Job.ID, summary => summary.Job.ID },                { StockMovement => StockMovement.Product.ID, summary => summary.Product.ID },                { StockMovement => StockMovement.Style.ID, summary => summary.Style.ID },                { StockMovement => StockMovement.Dimensions.UnitSize, summary => summary.Dimensions.UnitSize }            };    }        public class StockSummaryTotalRequiredFormula : IFormula<StockSummary, double>    {        public Expression<Func<StockSummary, double>> Value => x => x.Product.MinimumStockLevel;        public Expression<Func<StockSummary, double>>[] Modifiers => new Expression<Func<StockSummary, double>>[]        {            x => x.BillOfMaterials        };        public FormulaOperator Operator => FormulaOperator.Add;        public FormulaType Type => FormulaType.Virtual;    }        public class StockSummaryNettRequiredFormula : IFormula<StockSummary, double>    {        public Expression<Func<StockSummary, double>> Value => x => x.TotalRequired;        public Expression<Func<StockSummary, double>>[] Modifiers => new Expression<Func<StockSummary, double>>[]        {            x => x.Issued        };        public FormulaOperator Operator => FormulaOperator.Subtract;        public FormulaType Type => FormulaType.Virtual;    }        public class StockSummaryAllStockAggregate : CoreAggregate<StockSummary, 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<StockSummary, object>>> Links =>            new Dictionary<Expression<Func<StockMovement, object>>, Expression<Func<StockSummary, object>>>()            {                { StockMovement => StockMovement.Job.ID, summary => summary.Job.ID },                { StockMovement => StockMovement.Product.ID, summary => summary.Product.ID },                { StockMovement => StockMovement.Style.ID, summary => summary.Style.ID },                { StockMovement => StockMovement.Dimensions.UnitSize, summary => summary.Dimensions.UnitSize }            };    }    public class StockSummaryOrderAggregate : CoreAggregate<StockSummary, 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<StockSummary, object>>> Links =>            new Dictionary<Expression<Func<PurchaseOrderItem, object>>, Expression<Func<StockSummary, object>>>()            {                { PurchaseOrderItem => PurchaseOrderItem.Job.ID, summary => summary.Job.ID },                { PurchaseOrderItem => PurchaseOrderItem.Product.ID, summary => summary.Product.ID },                { PurchaseOrderItem => PurchaseOrderItem.Style.ID, summary => summary.Style.ID },                { PurchaseOrderItem => PurchaseOrderItem.Dimensions.UnitSize, summary => summary.Dimensions.UnitSize }            };        public override Filter<PurchaseOrderItem> Filter => new Filter<PurchaseOrderItem>(x => x.ReceivedDate).IsEqualTo(DateTime.MinValue);    }    public class StockSummaryTotalStockFormula : IFormula<StockSummary, double>    {        public Expression<Func<StockSummary, double>> Value => x => x.Issued;        public Expression<Func<StockSummary, double>>[] Modifiers => new Expression<Func<StockSummary, double>>[]        {            x => x.AllStock,            x => x.OnOrder        };        public FormulaOperator Operator => FormulaOperator.Add;        public FormulaType Type => FormulaType.Virtual;    }    public class StockSummaryBalanceAvailableFormula : IFormula<StockSummary, double>    {        public Expression<Func<StockSummary, double>> Value => x => x.TotalStock;        public Expression<Func<StockSummary, double>>[] Modifiers => new Expression<Func<StockSummary, double>>[]        {            x => x.TotalRequired        };        public FormulaOperator Operator => FormulaOperator.Subtract;        public FormulaType Type => FormulaType.Virtual;    }    public class StockSummaryUnionGenerator : AutoEntityUnionGenerator<IStockSummary>    {        protected override void Configure()        {            AddTable<StockMovement>();            AddTable<JobBillOfMaterialsItem>();            AddTable<JobRequisitionItem>();            AddTable<PurchaseOrderItem>();        }        public override bool Distinct => true;        public override Column<IStockSummary>[] IDColumns => new Column<IStockSummary>[]        {            new Column<IStockSummary>(x => x.Job.ID),            new Column<IStockSummary>(x => x.Product.ID),            new Column<IStockSummary>(x => x.Style.ID),            new Column<IStockSummary>(x => x.Dimensions.Unit.ID),            new Column<IStockSummary>(x => x.Dimensions.Quantity),            new Column<IStockSummary>(x => x.Dimensions.Length),            new Column<IStockSummary>(x => x.Dimensions.Width),            new Column<IStockSummary>(x => x.Dimensions.Height),            new Column<IStockSummary>(x => x.Dimensions.Weight)        };    }    public interface IStockSummary    {        JobLink Job { get; set; }        ProductLink Product { get; set; }        ProductStyleLink Style { get; set; }        StockDimensions Dimensions { get; set; }    }    [UserTracking(typeof(Product))]    [AutoEntity(typeof(StockSummaryUnionGenerator))]    public class StockSummary : StockEntity, IStockSummary, IRemotable, IPersistent    {        [NullEditor]        public JobLink Job { get; set; }        [EditorSequence(1)]        public override ProductLink Product { get; set; }        [EditorSequence(2)]        public ProductStyleLink Style { get; set; }        [EditorSequence(3)]        [RequiredColumn]        [DimensionsEditor(typeof(StockDimensions), AllowEditingUnit = false)]        public override StockDimensions Dimensions { get; set; }        [EditorSequence(4)]        [DoubleEditor]        [Aggregate(typeof(StockSummaryBOMAggregate))]        public double BillOfMaterials { get; set; }                [NullEditor]        [Formula(typeof(StockSummaryTotalRequiredFormula))]        public double TotalRequired { get; set; }        [EditorSequence(5)]        [Aggregate(typeof(StockSummaryIssuedAggregate))]        [DoubleEditor(Editable = Editable.Hidden)]        public double Issued { get; set; }                [NullEditor]        [Formula(typeof(StockSummaryNettRequiredFormula))]        public double NettRequired { get; set; }        [EditorSequence(6)]        [Aggregate(typeof(StockSummaryAllStockAggregate))]        [DoubleEditor(Editable = Editable.Hidden)]        public double AllStock { get; set; }        [EditorSequence(7)]        [DoubleEditor]        [Aggregate(typeof(StockSummaryOrderAggregate))]        public double OnOrder { get; set; }                [NullEditor]        [Formula(typeof(StockSummaryTotalStockFormula))]        public double TotalStock { get; set; }        [EditorSequence(8)]        [DoubleEditor]        [Formula(typeof(StockSummaryBalanceAvailableFormula))]        public double BalanceAvailable { get; set; }        protected override void Init()        {            base.Init();            Job = new JobLink();            Style = new ProductStyleLink();        }    }}
 |