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.
291 lines
11 KiB
291 lines
11 KiB
using Newtonsoft.Json;
|
|
using Swift.API.ThirdPartyApiServices;
|
|
using Swift.DAL.Remittance.ExchangeRate;
|
|
using Swift.DAL.SwiftDAL;
|
|
using Swift.web.Library;
|
|
using System;
|
|
using System.Data;
|
|
using System.IO;
|
|
using System.Text;
|
|
using System.Xml.Serialization;
|
|
using static Swift.API.Common.MapAPIData.APIBankModel;
|
|
|
|
namespace Swift.web.Remit.Transaction.DownloadTxn
|
|
{
|
|
public partial class DownloadInficareData : System.Web.UI.Page
|
|
{
|
|
ImportSettlementRateDao _isd = new ImportSettlementRateDao();
|
|
private readonly RemittanceLibrary _sl = new RemittanceLibrary();
|
|
protected ExchangeRateAPIService _map = new ExchangeRateAPIService();
|
|
private const string ViewFunctionId = "20150080";
|
|
|
|
protected void Page_Load(object sender, EventArgs e)
|
|
{
|
|
_sl.CheckSession();
|
|
string MethodName = Request.Form["MethodName"];
|
|
switch (MethodName)
|
|
{
|
|
case "MapData":
|
|
UpdateReferral();
|
|
break;
|
|
}
|
|
_sl.CheckAuthentication(ViewFunctionId);
|
|
if (!IsPostBack)
|
|
{
|
|
PopulateData();
|
|
fromDate.Text = DateTime.Now.ToString("yyyy-MM-dd");
|
|
toDate.Text = DateTime.Now.ToString("yyyy-MM-dd");
|
|
}
|
|
}
|
|
|
|
private void PopulateData()
|
|
{
|
|
DataSet ds = _isd.ShowInficareTempData(GetStatic.GetUser(), ddlMapped.SelectedValue);
|
|
|
|
DataTable dt = ds.Tables[1];
|
|
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() + ")";
|
|
txnNeedToBeApproved.InnerText = "Txns waiting for approval: " + ds.Tables[2].Rows[0][0].ToString();
|
|
|
|
if (null == dt || dt.Rows.Count == 0)
|
|
{
|
|
tranTable.InnerHtml = "<tr><td colspan=\"12\" align=\"center\">No data to display!</td></tr>";
|
|
return;
|
|
}
|
|
|
|
StringBuilder sb = new StringBuilder();
|
|
foreach (DataRow item in dt.Rows)
|
|
{
|
|
sb.AppendLine("<tr>");
|
|
sb.AppendLine("<td>" + item["TRANID"].ToString() + "</td>");
|
|
sb.AppendLine("<td>" + item["CONTROLNO"].ToString() + "</td>");
|
|
sb.AppendLine("<td>" + item["sempid"].ToString() + "</td>");
|
|
sb.AppendLine("<td>" + item["SENDERNAME"].ToString() + "</td>");
|
|
sb.AppendLine("<td>" + item["RECEIVERNAME"].ToString() + "</td>");
|
|
sb.AppendLine("<td>" + item["collMode"].ToString() + "</td>");
|
|
sb.AppendLine("<td>" + item["RECEIVERCOUNTRY"].ToString() + "</td>");
|
|
sb.AppendLine("<td>" + GetStatic.ShowDecimal(item["COLLECTAMOUNT"].ToString()) + "</td>");
|
|
sb.AppendLine("<td>" + GetStatic.ShowDecimal(item["SENTAMOUNT"].ToString()) + "</td>");
|
|
sb.AppendLine("<td>" + GetStatic.ShowDecimal(item["PAYOUTAMOUNT"].ToString()) + "</td>");
|
|
if (!string.IsNullOrEmpty(item["PROMOTIONCODE"].ToString()))
|
|
{
|
|
sb.AppendLine("<td>" + GetStatic.MakeAutoCompleteControl(item["TRANID"].ToString(), "'category' : 'remit-referralChange'", item["PROMOTIONCODE"].ToString(), item["REFERRAL"].ToString() + " | " + item["PROMOTIONCODE"].ToString()) + "</td>");
|
|
}
|
|
else
|
|
{
|
|
sb.AppendLine("<td>" + GetStatic.MakeAutoCompleteControl(item["TRANID"].ToString(), "'category' : 'remit-referralChange'") + "</td>");
|
|
}
|
|
sb.AppendLine("<td><input type=\"button\" onclick=\"SavedClicked('" + item["TRANID"].ToString() + "')\" class=\"btn btn-default\" id='save_" + item["TRANID"].ToString() + "' value=\"Save\"></td>");
|
|
sb.AppendLine("</tr>");
|
|
}
|
|
|
|
tranTable.InnerHtml = sb.ToString();
|
|
}
|
|
|
|
protected void downloadbtn_Click(object sender, EventArgs e)
|
|
{
|
|
string fDate = fromDate.Text;
|
|
string tDate = toDate.Text;
|
|
var url = "http://agent.jmejapan.com/account/GetTransactionList?passKey=jme.com.jp@1934321&dateFrom=" + fDate + "&dateTo=" + tDate;
|
|
var response = _map.DownloadInficareTransaction(url);
|
|
if (response[0].errorCode == "0")
|
|
{
|
|
var xml = ObjectToXML(response);
|
|
DbResult _dbRes = _isd.SaveTransactionInficare(GetStatic.GetUser(), xml, "TRANSACTION-DOWNLOAD");
|
|
if (_dbRes.ErrorCode == "0")
|
|
{
|
|
GetStatic.AlertMessage(this, _dbRes.Msg);
|
|
PopulateData();
|
|
}
|
|
else
|
|
{
|
|
GetStatic.AlertMessage(this, _dbRes.Msg);
|
|
}
|
|
//PopulateData();
|
|
}
|
|
else
|
|
{
|
|
GetStatic.AlertMessage(this, response[0].errorMsg);
|
|
}
|
|
}
|
|
public string ObjectToXML(object input)
|
|
{
|
|
try
|
|
{
|
|
var stringwriter = new StringWriter();
|
|
var serializer = new XmlSerializer(input.GetType());
|
|
serializer.Serialize(stringwriter, input);
|
|
return stringwriter.ToString();
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
if (ex.InnerException != null)
|
|
ex = ex.InnerException;
|
|
|
|
return "Could not convert: " + ex.Message;
|
|
}
|
|
}
|
|
|
|
protected void UpdateReferral()
|
|
{
|
|
DbResult _dbRes = new DbResult();
|
|
var tranId = Request.Form["TranId"];
|
|
var referralCode = Request.Form["ReferralCode"];
|
|
if (string.IsNullOrEmpty(tranId) || string.IsNullOrEmpty(referralCode))
|
|
{
|
|
_dbRes.SetError("1", "Required fields are mandatory!", null);
|
|
}
|
|
else
|
|
{
|
|
_dbRes = _isd.MapReferral(GetStatic.GetUser(), tranId, referralCode);
|
|
}
|
|
|
|
Response.ContentType = "application/json";
|
|
Response.Write(JsonConvert.SerializeObject(_dbRes));
|
|
Response.End();
|
|
}
|
|
|
|
protected void ddlMapped_SelectedIndexChanged(object sender, EventArgs e)
|
|
{
|
|
PopulateData();
|
|
}
|
|
|
|
protected void btnMapReferral_Click(object sender, EventArgs e)
|
|
{
|
|
if (fileReferral.FileContent.Length > 0)
|
|
{
|
|
if (fileReferral.FileName.ToLower().Contains(".csv"))
|
|
{
|
|
string path = Server.MapPath("..\\..\\..\\") + "\\doc\\tmp\\" + fileReferral.FileName;
|
|
string Remitpath = Server.MapPath("..\\..\\..\\") + "\\SampleFile\\FCYVoucherEntry\\" + fileReferral.FileName;
|
|
fileReferral.SaveAs(path);
|
|
var xml = GetStatic.GetCSVFileInTableForTxnSyncInficare(path, true);
|
|
|
|
//File.Move(path, Remitpath);
|
|
File.Delete(path);
|
|
var rs = _isd.UploadManualMap(GetStatic.GetUser(), xml);
|
|
if (rs.ErrorCode == "1")
|
|
{
|
|
GetStatic.AlertMessage(this, rs.Msg);
|
|
}
|
|
else
|
|
{
|
|
GetStatic.AlertMessage(this, rs.Msg);
|
|
PopulateData();
|
|
}
|
|
}
|
|
else
|
|
{
|
|
GetStatic.AlertMessage(this, "Invalid file format uploaded");
|
|
}
|
|
}
|
|
}
|
|
|
|
protected void btnFinalSave_Click(object sender, EventArgs e)
|
|
{
|
|
var rs = _isd.FinalSave(GetStatic.GetUser());
|
|
if (rs.ErrorCode == "1")
|
|
{
|
|
GetStatic.AlertMessage(this, rs.Msg);
|
|
}
|
|
else
|
|
{
|
|
GetStatic.AlertMessage(this, rs.Msg);
|
|
}
|
|
PopulateData();
|
|
}
|
|
|
|
protected void downloadForSync_Click(object sender, EventArgs e)
|
|
{
|
|
|
|
}
|
|
|
|
protected void btnClear_Click(object sender, EventArgs e)
|
|
{
|
|
_isd.ClearTempData(GetStatic.GetUser());
|
|
PopulateData();
|
|
}
|
|
|
|
protected void btnSyncPaid_Click(object sender, EventArgs e)
|
|
{
|
|
string fDate = fromDate.Text;
|
|
string tDate = toDate.Text;
|
|
var url = "http://agent.jmejapan.com/account/GetTransactionStatus?passKey=jme.com.jp@1934321&DateType=1&dateFrom=" + fDate + "&dateTo=" + tDate;
|
|
var response = _map.DownloadInficareTransactionForSync(url);
|
|
if (response[0].errorCode == "0")
|
|
{
|
|
var xml = ObjectToXML(response);
|
|
DbResult _dbRes = _isd.SaveTransactionInficare(GetStatic.GetUser(), xml, "SYNC-PAID");
|
|
if (_dbRes.ErrorCode == "0")
|
|
{
|
|
GetStatic.AlertMessage(this, _dbRes.Msg);
|
|
PopulateData();
|
|
}
|
|
else
|
|
{
|
|
GetStatic.AlertMessage(this, _dbRes.Msg);
|
|
}
|
|
//PopulateData();
|
|
}
|
|
else
|
|
{
|
|
GetStatic.AlertMessage(this, response[0].errorMsg);
|
|
}
|
|
}
|
|
|
|
protected void btnSyncCancel_Click(object sender, EventArgs e)
|
|
{
|
|
string fDate = fromDate.Text;
|
|
string tDate = toDate.Text;
|
|
var url = "http://agent.jmejapan.com/account/GetTransactionStatus?passKey=jme.com.jp@1934321&DateType=2&dateFrom=" + fDate + "&dateTo=" + tDate;
|
|
var response = _map.DownloadInficareTransactionForSync(url);
|
|
if (response[0].errorCode == "0")
|
|
{
|
|
var xml = ObjectToXML(response);
|
|
DbResult _dbRes = _isd.SaveTransactionInficare(GetStatic.GetUser(), xml, "SYNC-CANCEL");
|
|
if (_dbRes.ErrorCode == "0")
|
|
{
|
|
GetStatic.AlertMessage(this, _dbRes.Msg);
|
|
PopulateData();
|
|
}
|
|
else
|
|
{
|
|
GetStatic.AlertMessage(this, _dbRes.Msg);
|
|
}
|
|
//PopulateData();
|
|
}
|
|
else
|
|
{
|
|
GetStatic.AlertMessage(this, response[0].errorMsg);
|
|
}
|
|
}
|
|
|
|
protected void btnExecuteSelected_Click(object sender, EventArgs e)
|
|
{
|
|
var selectedOption = Request.Form["checkBoxSync"];
|
|
DbResult _dbRes = new DbResult();
|
|
|
|
if (selectedOption == "1")
|
|
_dbRes = _isd.RunJob(GetStatic.GetUser(), "Approve Transaction");
|
|
else if (selectedOption == "2")
|
|
_dbRes = _isd.RunVaultTransfer(GetStatic.GetUser());
|
|
else
|
|
_dbRes.SetError("1", "Please choose any one operation to execute!", "");
|
|
|
|
GetStatic.AlertMessage(this, _dbRes.Msg);
|
|
}
|
|
|
|
protected void btnClearTemp_Click(object sender, EventArgs e)
|
|
{
|
|
var _dbRes = _isd.RunJob(GetStatic.GetUser(), "Approve Transaction");
|
|
if (_dbRes.ErrorCode == "0")
|
|
{
|
|
var returnResp = _isd.ClearTempTranData(GetStatic.GetUser());
|
|
GetStatic.AlertMessage(this, returnResp.Msg);
|
|
}
|
|
else
|
|
{
|
|
GetStatic.AlertMessage(this, "Txn Approve job is running you can not clear remittrantemp data");
|
|
}
|
|
}
|
|
}
|
|
}
|