You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

145 lines
5.9 KiB

  1. using Swift.API.ThirdPartyApiServices;
  2. using Swift.DAL.Remittance.ExchangeRate;
  3. using Swift.DAL.SwiftDAL;
  4. using Swift.web.Library;
  5. using System;
  6. using System.Data;
  7. using System.IO;
  8. using System.Text;
  9. using System.Xml.Serialization;
  10. namespace Swift.web.AgentNew.Administration.TransactionSync
  11. {
  12. public partial class TxnDownload : System.Web.UI.Page
  13. {
  14. ImportSettlementRateDao _isd = new ImportSettlementRateDao();
  15. private readonly RemittanceLibrary _sl = new RemittanceLibrary();
  16. protected ExchangeRateAPIService _map = new ExchangeRateAPIService();
  17. private const string ViewFunctionId = "20202900";
  18. protected void Page_Load(object sender, EventArgs e)
  19. {
  20. _sl.HasRight(ViewFunctionId);
  21. _sl.CheckSession();
  22. string MethodName = Request.Form["MethodName"];
  23. switch (MethodName)
  24. {
  25. case "MapData":
  26. UpdateReferral();
  27. break;
  28. }
  29. if (!IsPostBack)
  30. {
  31. PopulateData();
  32. }
  33. }
  34. private void PopulateData()
  35. {
  36. DataSet ds = _isd.ShowInficareTempData(GetStatic.GetUser(), ddlMapped.SelectedValue);
  37. DataTable dt = ds.Tables[1];
  38. numberOfTxns.InnerText = "Total number of transactions: " + ds.Tables[0].Rows[0][0].ToString() + " (Referral Mapped: " + ds.Tables[0].Rows[0][1].ToString() + " Unmapped: " + ds.Tables[0].Rows[0][2].ToString() + ")";
  39. if (null == dt || dt.Rows.Count == 0)
  40. {
  41. tranTable.InnerHtml = "<tr><td colspan=\"12\" align=\"center\">No data to display!</td></tr>";
  42. return;
  43. }
  44. StringBuilder sb = new StringBuilder();
  45. foreach (DataRow item in dt.Rows)
  46. {
  47. sb.AppendLine("<tr>");
  48. sb.AppendLine("<td>" + item["TRANID"].ToString() + "</td>");
  49. sb.AppendLine("<td>" + item["CONTROLNO"].ToString() + "</td>");
  50. sb.AppendLine("<td>" + item["sempid"].ToString() + "</td>");
  51. sb.AppendLine("<td>" + item["SENDERNAME"].ToString() + "</td>");
  52. sb.AppendLine("<td>" + item["RECEIVERNAME"].ToString() + "</td>");
  53. sb.AppendLine("<td>" + item["collMode"].ToString() + "</td>");
  54. sb.AppendLine("<td>" + item["RECEIVERCOUNTRY"].ToString() + "</td>");
  55. sb.AppendLine("<td>" + GetStatic.ShowDecimal(item["COLLECTAMOUNT"].ToString()) + "</td>");
  56. sb.AppendLine("<td>" + GetStatic.ShowDecimal(item["SENTAMOUNT"].ToString()) + "</td>");
  57. sb.AppendLine("<td>" + GetStatic.ShowDecimal(item["PAYOUTAMOUNT"].ToString()) + "</td>");
  58. if (!string.IsNullOrEmpty(item["PROMOTIONCODE"].ToString()))
  59. {
  60. sb.AppendLine("<td>" + GetStatic.MakeAutoCompleteControl(item["TRANID"].ToString(), "'category' : 'remit-referralChange'", item["PROMOTIONCODE"].ToString(), item["REFERRAL"].ToString() + " | " + item["PROMOTIONCODE"].ToString()) + "</td>");
  61. }
  62. else
  63. {
  64. sb.AppendLine("<td>" + GetStatic.MakeAutoCompleteControl(item["TRANID"].ToString(), "'category' : 'remit-referralChange'") + "</td>");
  65. }
  66. sb.AppendLine("<td><input type=\"button\" onclick=\"SavedClicked('" + item["TRANID"].ToString() + "')\" class=\"btn btn-default\" id='save_" + item["TRANID"].ToString() + "' value=\"Save\"></td>");
  67. sb.AppendLine("</tr>");
  68. }
  69. tranTable.InnerHtml = sb.ToString();
  70. }
  71. protected void downloadbtn_Click(object sender, EventArgs e)
  72. {
  73. string fDate = DateTime.Now.ToString("yyyy-MM-dd");
  74. string tDate = DateTime.Now.ToString("yyyy-MM-dd");
  75. var url = "http://agent.jmejapan.com/account/GetTransactionList?passKey=jme.com.jp@1934321&dateFrom=" + fDate + "&dateTo=" + tDate;
  76. var response = _map.DownloadInficareTransaction(url);
  77. if (response[0].errorCode == "0")
  78. {
  79. var xml = ObjectToXML(response);
  80. DbResult _dbRes = _isd.SaveTransactionInficare(GetStatic.GetUser(), xml, "TRANSACTION-DOWNLOAD");
  81. if (_dbRes.ErrorCode == "0")
  82. {
  83. GetStatic.AlertMessage(this, _dbRes.Msg);
  84. PopulateData();
  85. }
  86. else
  87. {
  88. GetStatic.AlertMessage(this, _dbRes.Msg);
  89. }
  90. //PopulateData();
  91. }
  92. else
  93. {
  94. GetStatic.AlertMessage(this, response[0].errorMsg);
  95. }
  96. }
  97. public string ObjectToXML(object input)
  98. {
  99. try
  100. {
  101. var stringwriter = new StringWriter();
  102. var serializer = new XmlSerializer(input.GetType());
  103. serializer.Serialize(stringwriter, input);
  104. return stringwriter.ToString();
  105. }
  106. catch (Exception ex)
  107. {
  108. if (ex.InnerException != null)
  109. ex = ex.InnerException;
  110. return "Could not convert: " + ex.Message;
  111. }
  112. }
  113. protected void UpdateReferral()
  114. {
  115. DbResult _dbRes = new DbResult();
  116. var tranId = Request.Form["TranId"];
  117. var referralCode = Request.Form["ReferralCode"];
  118. if (string.IsNullOrEmpty(tranId) || string.IsNullOrEmpty(referralCode))
  119. {
  120. _dbRes.SetError("1", "Required fields are mandatory!", null);
  121. }
  122. else
  123. {
  124. _dbRes = _isd.MapReferral(GetStatic.GetUser(), tranId, referralCode);
  125. }
  126. GetStatic.JsonResponse(_dbRes, this);
  127. }
  128. protected void ddlMapped_SelectedIndexChanged(object sender, EventArgs e)
  129. {
  130. PopulateData();
  131. }
  132. }
  133. }