ReceiptMYOBPoster.cs 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. using Comal.Classes;
  2. using InABox.Core;
  3. using InABox.Poster.MYOB;
  4. using MYOB.AccountRight.SDK.Contracts.Version2.Sale;
  5. using MYOB.AccountRight.SDK.Services.Sale;
  6. using System;
  7. using System.Collections.Generic;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. using System.Windows.Markup.Localizer;
  12. using Invoice = Comal.Classes.Invoice;
  13. using MYOBReceipt = MYOB.AccountRight.SDK.Contracts.Version2.Sale.CustomerPayment;
  14. namespace PRS.Shared.Posters.MYOB;
  15. public class ReceiptMYOBPosterSettings : MYOBPosterSettings
  16. {
  17. }
  18. public class ReceiptMYOBPoster : IMYOBPoster<Receipt, ReceiptMYOBPosterSettings>
  19. {
  20. public MYOBConnectionData ConnectionData { get; set; }
  21. public ReceiptMYOBPosterSettings Settings { get; set; }
  22. public MYOBGlobalPosterSettings GlobalSettings { get; set; }
  23. public bool BeforePost(IDataModel<Receipt> model)
  24. {
  25. foreach(var (_, table) in model.ModelTables)
  26. {
  27. table.ShouldLoad = false;
  28. }
  29. model.SetShouldLoad<Receipt>(true);
  30. model.SetColumns<Receipt>(RequiredReceiptColumns());
  31. model.SetIsDefault<InvoiceReceipt>(true, alias: "Receipt_InvoiceReceipt");
  32. model.SetColumns<InvoiceReceipt>(RequiredInvoiceReceiptColumns(), alias: "Receipt_InvoiceReceipt");
  33. model.SetIsDefault<Customer>(true, alias: "Receipt_Customer");
  34. model.SetColumns<Customer>(RequiredCustomerColumns(), alias: "Receipt_Customer");
  35. return true;
  36. }
  37. private static Columns<Receipt> RequiredReceiptColumns()
  38. {
  39. return Columns.None<Receipt>()
  40. .Add(x => x.ID)
  41. .Add(x => x.PostedReference)
  42. .Add(x => x.CustomerLink.ID)
  43. .Add(x => x.Date)
  44. .Add(x => x.Total)
  45. .Add(x => x.Notes);
  46. }
  47. private static Columns<InvoiceReceipt> RequiredInvoiceReceiptColumns()
  48. {
  49. return Columns.None<InvoiceReceipt>()
  50. .Add(x => x.ID)
  51. .Add(x => x.Amount)
  52. .Add(x => x.ReceiptLink.ID)
  53. .Add(x => x.InvoiceLink.Number)
  54. .Add(x => x.InvoiceLink.PostedReference);
  55. }
  56. private static Columns<Customer> RequiredCustomerColumns()
  57. {
  58. return CustomerMYOBPoster.RequiredColumns();
  59. }
  60. public IPostResult<Receipt> Process(IDataModel<Receipt> model)
  61. {
  62. var results = new PostResult<Receipt>();
  63. var service = new CustomerPaymentService(ConnectionData.Configuration, null, ConnectionData.AuthKey);
  64. var receipts = model.GetTable<Receipt>().ToArray<Receipt>();
  65. var customers = model.GetTable<Customer>("Receipt_Customer")
  66. .ToObjects<Customer>().ToDictionary(x => x.ID);
  67. var invoices = model.GetTable<InvoiceReceipt>("Receipt_InvoiceReceipt")
  68. .ToObjects<InvoiceReceipt>().GroupBy(x => x.ReceiptLink.ID).ToDictionary(x => x.Key, x => x.ToArray());
  69. foreach(var receipt in receipts)
  70. {
  71. bool isNew;
  72. MYOBReceipt myobReceipt;
  73. Exception? error;
  74. if(Guid.TryParse(receipt.PostedReference, out var myobID))
  75. {
  76. if(!service.Get(ConnectionData, myobID).Get(out var newReceipt, out error))
  77. {
  78. CoreUtils.LogException("", error, $"Failed to find Receipt in MYOB with id {myobID}");
  79. results.AddFailed(receipt, $"Failed to find Receipt in MYOB with id {myobID}: {error.Message}");
  80. continue;
  81. }
  82. myobReceipt = newReceipt;
  83. isNew = false;
  84. }
  85. else
  86. {
  87. myobReceipt = new MYOBReceipt();
  88. isNew = true;
  89. }
  90. myobReceipt.DepositTo = DepositTo.UndepositedFunds;
  91. // Setting this to null right now.
  92. myobReceipt.Account.UID = Guid.Empty;
  93. // Account =
  94. if(customers.TryGetValue(receipt.CustomerLink.ID, out var customer))
  95. {
  96. if(!CustomerMYOBPoster.MapCustomer(ConnectionData, customer).Get(out var customerID, out error))
  97. {
  98. CoreUtils.LogException("", error, $"Error while posting receipt {receipt.ID}");
  99. results.AddFailed(receipt, error.Message);
  100. continue;
  101. }
  102. myobReceipt.Customer.UID = customerID;
  103. }
  104. // myobReceipt.ReceiptNumber =
  105. myobReceipt.Date = receipt.Date;
  106. myobReceipt.AmountReceived = (decimal)receipt.Total;
  107. // myobReceipt.AmountReceivedForeign = 0;
  108. // myobReceipt.PaymentMethod =
  109. myobReceipt.Memo = receipt.Notes.Truncate(255);
  110. if(invoices.TryGetValue(receipt.ID, out var receiptInvoices))
  111. {
  112. var myobInvoices = new CustomerPaymentLine[receiptInvoices.Length];
  113. string? failed = null;
  114. for(int i = 0; i < receiptInvoices.Length; ++i)
  115. {
  116. var invoice = receiptInvoices[i];
  117. var line = new CustomerPaymentLine();
  118. line.RowID = i + 1;
  119. line.Number = invoice.InvoiceLink.Number.ToString().Truncate(8);
  120. line.AmountApplied = (decimal)invoice.Amount;
  121. line.Type = CustomerPaymentLineType.Invoice;
  122. if(Guid.TryParse(invoice.InvoiceLink.PostedReference, out var myobInvoiceID))
  123. {
  124. line.UID = myobInvoiceID;
  125. }
  126. else
  127. {
  128. failed = $"Invoice {invoice.InvoiceLink.Number} hasn't been posted yet; it must be posted before this receipt can be.";
  129. break;
  130. }
  131. myobInvoices[i] = line;
  132. }
  133. if(failed is not null)
  134. {
  135. results.AddFailed(receipt, failed);
  136. continue;
  137. }
  138. myobReceipt.Invoices = [];
  139. }
  140. else
  141. {
  142. myobReceipt.Invoices = [];
  143. }
  144. try
  145. {
  146. var result = service.UpdateEx(ConnectionData.CompanyFile, myobReceipt, ConnectionData.CompanyFileCredentials);
  147. receipt.PostedReference = result.UID.ToString();
  148. results.AddSuccess(receipt);
  149. }
  150. catch(Exception e)
  151. {
  152. CoreUtils.LogException("", e, $"Error while posting receipt {receipt.ID}");
  153. results.AddFailed(receipt, e.Message);
  154. }
  155. }
  156. return results;
  157. }
  158. }