StockLocationLookups.cs 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using InABox.Clients;
  5. using InABox.Core;
  6. namespace Comal.Classes
  7. {
  8. public class StockLocationLookups : EntityLookup<StockLocation>, ILookupDefinition<StockLocation, Product>,
  9. ILookupDefinition<StockLocation, RequisitionItem>
  10. {
  11. // If there are multiple items, they must be all in the same warehouse
  12. public Filter<StockLocation> DefineFilter(Product[] items)
  13. {
  14. var warehouses = items.Select(x => x.Warehouse.ID).Distinct().ToArray();
  15. if (warehouses.Length == 1)
  16. return new Filter<StockLocation>(x => x.Active).IsEqualTo(true).And(x => x.Warehouse.ID).IsEqualTo(warehouses.First());
  17. return new Filter<StockLocation>(x => x.ID).IsEqualTo(CoreUtils.FullGuid);
  18. }
  19. Columns<Product> ILookupDefinition<StockLocation, Product>.DefineFilterColumns()
  20. => new Columns<Product>(x => x.Warehouse.ID);
  21. public Filter<StockLocation> DefineFilter(RequisitionItem[] items)
  22. {
  23. var productid = items.Select(x => x.Product.ID).FirstOrDefault();
  24. var styleid = items.Select(x => x.Style.ID).FirstOrDefault();
  25. var unitsize = items.Select(x => x.Dimensions.UnitSize).FirstOrDefault();
  26. var result = new Filter<StockLocation>(x => x.ID).InQuery<StockHolding>(
  27. new Filter<StockHolding>(x => x.Product.ID).IsEqualTo(productid)
  28. .And(x=>x.Style.ID).IsEqualTo(styleid)
  29. .And(x=>x.Dimensions.UnitSize).IsEqualTo(unitsize)
  30. .And(x => x.Qty).IsGreaterThan(0.0F),
  31. x => x.Location.ID);
  32. return result;
  33. }
  34. Columns<RequisitionItem> ILookupDefinition<StockLocation, RequisitionItem>.DefineFilterColumns()
  35. => new Columns<RequisitionItem>(x => x.Product.ID).Add(x => x.Style.ID);
  36. public override Columns<StockLocation> DefineColumns()
  37. {
  38. return new Columns<StockLocation>
  39. (
  40. x => x.ID,
  41. x => x.Code,
  42. x => x.Area.Warehouse.Description,
  43. x => x.Area.Description,
  44. x => x.Description
  45. );
  46. }
  47. public override Filter<StockLocation> DefineFilter()
  48. {
  49. return new Filter<StockLocation>(x => x.Active).IsEqualTo(true);
  50. }
  51. public override SortOrder<StockLocation> DefineSortOrder()
  52. {
  53. return new SortOrder<StockLocation>(x => x.Code);
  54. }
  55. }
  56. }