Update_7_63.cs 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. using com.sun.net.ssl.@internal.ssl;
  2. using Comal.Classes;
  3. using InABox.Core;
  4. using InABox.Database;
  5. using System.Collections.Generic;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. namespace PRS.Shared.Database_Update_Scripts;
  10. public class Update_7_63 : DatabaseUpdateScript
  11. {
  12. public override VersionNumber Version => new VersionNumber(7, 63);
  13. public override bool Update()
  14. {
  15. Logger.Send(LogType.Information, "", $"Updating uninitialised stock movement types");
  16. int iCount = 0;
  17. while (true)
  18. {
  19. var movements = DbFactory.NewProvider(Logger.Main).Query(typeof(StockMovement),
  20. new Filter<StockMovement>(x => x.Type).IsEqualTo(null),
  21. Columns.None<StockMovement>().Add(x => x.ID)
  22. .Add(x => x.Received)
  23. .Add(x => x.Issued)
  24. .Add(x => x.Batch.Type)
  25. .Add("IsTransfer"),
  26. null,
  27. CoreRange.Database(1000));
  28. if (movements.Rows.Count == 0)
  29. break;
  30. iCount += movements.Rows.Count;
  31. Logger.Send(LogType.Information, "", $"Updating {iCount} movements");
  32. List<StockMovement> updates = new List<StockMovement>();
  33. foreach(var row in movements.Rows)
  34. {
  35. var istransfer = row.Get<bool>("IsTransfer");
  36. var movement = row.ToObject<StockMovement>();
  37. if (istransfer)
  38. {
  39. if(movement.Received > 0)
  40. {
  41. movement.Type = StockMovementType.TransferIn;
  42. }
  43. else
  44. {
  45. movement.Type = StockMovementType.TransferOut;
  46. }
  47. }
  48. else if(movement.Batch.Type == StockMovementBatchType.Stocktake)
  49. {
  50. movement.Type = StockMovementType.StockTake;
  51. }
  52. else if(movement.Received > 0)
  53. {
  54. movement.Type = StockMovementType.Receive;
  55. }
  56. else
  57. {
  58. movement.Type = StockMovementType.Issue;
  59. }
  60. // manually setting original value because originally the same.
  61. movement.SetOriginalValue(x => x.Type, StockMovementType.Receive);
  62. updates.Add(movement);
  63. }
  64. DbFactory.NewProvider(Logger.Main).Save(updates);
  65. }
  66. return true;
  67. }
  68. }