PurchaseOrderStore.cs 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. using Comal.Classes;
  2. using InABox.Core;
  3. using NPOI.HPSF;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using PRSStores;
  7. using System;
  8. namespace Comal.Stores
  9. {
  10. public class PurchaseOrderStore : BaseStore<PurchaseOrder>
  11. {
  12. protected override void BeforeSave(PurchaseOrder entity)
  13. {
  14. base.BeforeSave(entity);
  15. Guid? empid = null;
  16. if (entity.ID == Guid.Empty)
  17. {
  18. empid ??= GetEmployeeIDFromUserGuid();
  19. entity.RaisedBy.ID = empid.Value;
  20. }
  21. }
  22. protected override void AfterSave(PurchaseOrder entity)
  23. {
  24. base.AfterSave(entity);
  25. UpdateTrackingKanban<PurchaseOrderKanban, PurchaseOrder, PurchaseOrderLink>(entity, p =>
  26. {
  27. return !p.ClosedDate.IsEmpty()
  28. ? KanbanStatus.Complete
  29. : !p.IssuedDate.IsEmpty()
  30. ? KanbanStatus.Waiting
  31. : KanbanStatus.Open;
  32. });
  33. }
  34. private Guid[] JobRequisitionItemIDs = System.Array.Empty<Guid>();
  35. private Guid[] GetJobRequisitionIDs(PurchaseOrder entity)
  36. {
  37. var jris = Provider.Query(
  38. new Filter<PurchaseOrderItemAllocation>(x => x.Item.PurchaseOrderLink.ID).IsEqualTo(entity.ID),
  39. Columns.Required<PurchaseOrderItemAllocation>()
  40. ).Rows
  41. .Select(r=>r.Get<PurchaseOrderItemAllocation, Guid>(x => x.JobRequisitionItem.ID))
  42. .Where(x=> x != Guid.Empty)
  43. .Distinct()
  44. .ToArray();
  45. return jris;
  46. }
  47. protected override void BeforeDelete(PurchaseOrder entity)
  48. {
  49. UnlinkTrackingKanban<PurchaseOrderKanban, PurchaseOrder, PurchaseOrderLink>(entity);
  50. DeleteStockMovements(entity);
  51. JobRequisitionItemIDs = GetJobRequisitionIDs(entity);
  52. }
  53. private void DeleteStockMovements(PurchaseOrder entity)
  54. {
  55. var items = Provider.Query(
  56. new Filter<PurchaseOrderItem>(x => x.PurchaseOrderLink.ID).IsEqualTo(entity.ID),
  57. Columns.None<PurchaseOrderItem>().Add(x => x.ID)
  58. ).Rows.Select(x => x.ToObject<PurchaseOrderItem>());
  59. List<Guid> ids = new List<Guid>();
  60. foreach ( var item in items)
  61. ids.Add(item.ID);
  62. var movements = Provider.Query(
  63. new Filter<StockMovement>(x => x.OrderItem.ID).InList(ids.ToArray()),
  64. Columns.None<StockMovement>().Add(x => x.ID)
  65. ).Rows.Select(x => x.ToObject<StockMovement>());
  66. if (movements.Any())
  67. FindSubStore<StockMovement>().Delete(movements, "Purchase Order Deleted");
  68. }
  69. }
  70. }