PurchaseOrderStore.cs 2.8 KB

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