PurchaseOrderStore.cs 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  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<JobRequisitionItemPurchaseOrderItem>(x => x.PurchaseOrderItem.PurchaseOrderLink.ID).IsEqualTo(entity.ID),
  39. Columns.None<JobRequisitionItemPurchaseOrderItem>().Add(x => x.JobRequisitionItem.ID))
  40. .Rows
  41. .Select(r=>r.Get<JobRequisitionItemPurchaseOrderItem, 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. protected override void AfterDelete(PurchaseOrder entity)
  54. {
  55. base.AfterDelete(entity);
  56. foreach (var id in JobRequisitionItemIDs)
  57. JobRequisitionItemStore.UpdateStatus(this, id, JobRequisitionItemAction.Deleted);
  58. }
  59. private void DeleteStockMovements(PurchaseOrder entity)
  60. {
  61. var items = Provider.Query(
  62. new Filter<PurchaseOrderItem>(x => x.PurchaseOrderLink.ID).IsEqualTo(entity.ID),
  63. Columns.None<PurchaseOrderItem>().Add(x => x.ID)
  64. ).Rows.Select(x => x.ToObject<PurchaseOrderItem>());
  65. List<Guid> ids = new List<Guid>();
  66. foreach ( var item in items)
  67. ids.Add(item.ID);
  68. var movements = Provider.Query(
  69. new Filter<StockMovement>(x => x.OrderItem.ID).InList(ids.ToArray()),
  70. Columns.None<StockMovement>().Add(x => x.ID)
  71. ).Rows.Select(x => x.ToObject<StockMovement>());
  72. if (movements.Any())
  73. FindSubStore<StockMovement>().Delete(movements, "Purchase Order Deleted");
  74. }
  75. }
  76. }