/* * 流量卡分佣交易 */ using System; using System.Web; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using System.Threading.Tasks; using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Http; using Microsoft.Extensions.Logging; using Microsoft.Extensions.Options; using MySystem.SpModels; using Library; using LitJson; using MySystemLib; namespace MySystem.Areas.Admin.Controllers { [Area("Admin")] [Route("Admin/[controller]/[action]")] public class TradeFluxRecordController : BaseController { public TradeFluxRecordController(IHttpContextAccessor accessor, ILogger logger, IOptions setting) : base(accessor, logger, setting) { OtherMySqlConn.connstr = ConfigurationManager.AppSettings["SpSqlConnStr"].ToString(); } #region 流量卡分佣交易列表 /// /// 根据条件查询流量卡分佣交易列表 /// /// public IActionResult Index(TradeFluxRecord data, string right) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; return View(); } #endregion #region 根据条件查询流量卡分佣交易列表 /// /// 流量卡分佣交易列表 /// /// public JsonResult IndexData(TradeFluxRecord data, string TradeStatusSelect, string ProductTypeSelect, string CreateDateData, int page = 1, int limit = 30) { Dictionary Fields = new Dictionary(); Fields.Add("MerNo", "1"); //商户编号 Fields.Add("TradeSnNo", "1"); //终端机身号 Fields.Add("KqTradeSeq", "1"); //快钱交易流水号 string condition = " and Status>-1"; //交易状态 if (!string.IsNullOrEmpty(TradeStatusSelect)) { condition += " and TradeStatus=" + TradeStatusSelect; } //产品类型 if (!string.IsNullOrEmpty(ProductTypeSelect)) { condition += " and ProductType=" + ProductTypeSelect; } //创建时间 if (!string.IsNullOrEmpty(CreateDateData)) { string[] datelist = CreateDateData.Split(new string[] { " - " }, StringSplitOptions.None); string start = datelist[0]; string end = datelist[1]; condition += " and CreateDate>='" + start + " 00:00:00' and CreateDate<='" + end + " 23:59:59'"; } Dictionary obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.SpTables).IndexData("TradeFluxRecord", Fields, "Id desc", "0", page, limit, condition); List> diclist = obj["data"] as List>; foreach (Dictionary dic in diclist) { //状态 string Status = dic["Status"].ToString(); if (Status == "1") dic["Status"] = "待同步"; if (Status == "2") dic["Status"] = "已同步"; if (Status == "") dic["Status"] = ""; //交易状态 string TradeStatus = dic["TradeStatus"].ToString(); if (TradeStatus == "1") dic["TradeStatus"] = "成功"; if (TradeStatus == "2") dic["TradeStatus"] = "失败"; if (TradeStatus == "") dic["TradeStatus"] = ""; //银行卡类型 string BankCardType = dic["BankCardType"].ToString(); if (BankCardType == "0001") dic["BankCardType"] = "贷记卡"; if (BankCardType == "0002") dic["BankCardType"] = "借记卡"; if (BankCardType == "") dic["BankCardType"] = ""; //流量费 decimal FeeAmount = Convert.ToDecimal(dic["FeeAmount"].ToString()); var Brand = dic["ProductType"].ToString(); if (Brand == "1" || Brand == "4" || Brand == "6" || Brand == "8" || Brand == "9") { dic["FeeAmount"] = FeeAmount / 100; } if (Brand == "2" || Brand == "7") { dic["FeeAmount"] = FeeAmount; } //产品类型 dic["ProductType"] = RelationClass.GetKqProductBrandList(dic["ProductType"].ToString()); // //产品类型 // string ProductType = dic["ProductType"].ToString(); // if (ProductType == "KYSPOS") dic["ProductType"] = "快益刷"; // if (ProductType == "KPOS") dic["ProductType"] = "快联盟大POS"; // if (ProductType == "SIGNPOS") dic["ProductType"] = "快联盟电签POS"; // if (ProductType == "SUPPOS") dic["ProductType"] = "超级Mpos"; // if (ProductType == "") dic["ProductType"] = ""; } return Json(obj); } #endregion #region 增加流量卡分佣交易 /// /// 增加或修改流量卡分佣交易信息 /// /// public IActionResult Add(string right) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; return View(); } #endregion #region 增加流量卡分佣交易 /// /// 增加或修改流量卡分佣交易信息 /// /// [HttpPost] public string Add(TradeFluxRecord data) { Dictionary Fields = new Dictionary(); Fields.Add("SeoTitle", data.SeoTitle); Fields.Add("SeoKeyword", data.SeoKeyword); Fields.Add("SeoDescription", data.SeoDescription); int Id = new AdminContentOther(_accessor.HttpContext, PublicFunction.SpTables).Add("TradeFluxRecord", Fields, 0); AddSysLog(data.Id.ToString(), "TradeFluxRecord", "add"); spdb.SaveChanges(); return "success"; } #endregion #region 修改流量卡分佣交易 /// /// 增加或修改流量卡分佣交易信息 /// /// public IActionResult Edit(string right, int Id = 0) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; TradeFluxRecord editData = spdb.TradeFluxRecord.FirstOrDefault(m => m.Id == Id) ?? new TradeFluxRecord(); ViewBag.data = editData; return View(); } #endregion #region 修改流量卡分佣交易 /// /// 增加或修改流量卡分佣交易信息 /// /// [HttpPost] public string Edit(TradeFluxRecord data) { Dictionary Fields = new Dictionary(); Fields.Add("SeoTitle", data.SeoTitle); Fields.Add("SeoKeyword", data.SeoKeyword); Fields.Add("SeoDescription", data.SeoDescription); new AdminContentOther(_accessor.HttpContext, PublicFunction.SpTables).Edit("TradeFluxRecord", Fields, data.Id); AddSysLog(data.Id.ToString(), "TradeFluxRecord", "update"); spdb.SaveChanges(); return "success"; } #endregion #region 删除流量卡分佣交易信息 /// /// 删除流量卡分佣交易信息 /// /// public string Delete(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "TradeFluxRecord", "del"); foreach (string subid in idlist) { int id = int.Parse(subid); Dictionary Fields = new Dictionary(); Fields.Add("Status", -1); new AdminContentOther(_accessor.HttpContext, PublicFunction.SpTables).Edit("TradeFluxRecord", Fields, id); } spdb.SaveChanges(); return "success"; } #endregion #region 开启 /// /// 开启 /// /// public string Open(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "TradeFluxRecord", "open"); foreach (string subid in idlist) { int id = int.Parse(subid); Dictionary Fields = new Dictionary(); Fields.Add("Status", 1); new AdminContentOther(_accessor.HttpContext, PublicFunction.SpTables).Edit("TradeFluxRecord", Fields, id); } spdb.SaveChanges(); return "success"; } #endregion #region 关闭 /// /// 关闭 /// /// public string Close(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "TradeFluxRecord", "close"); foreach (string subid in idlist) { int id = int.Parse(subid); Dictionary Fields = new Dictionary(); Fields.Add("Status", 0); new AdminContentOther(_accessor.HttpContext, PublicFunction.SpTables).Edit("TradeFluxRecord", Fields, id); } spdb.SaveChanges(); return "success"; } #endregion #region 排序 /// /// 排序 /// /// public string Sort(int Id, int Sort) { new AdminContentOther(_accessor.HttpContext, PublicFunction.SpTables).Sort("TradeFluxRecord", Sort, Id); AddSysLog(Id.ToString(), "TradeFluxRecord", "sort"); return "success"; } #endregion #region 导入数据 /// /// 导入数据 /// /// public string Import(string ExcelData) { ExcelData = HttpUtility.UrlDecode(ExcelData); JsonData list = JsonMapper.ToObject(ExcelData); for (int i = 1; i < list.Count; i++) { JsonData dr = list[i]; spdb.TradeFluxRecord.Add(new TradeFluxRecord() { CreateDate = DateTime.Now, UpdateDate = DateTime.Now, }); spdb.SaveChanges(); } AddSysLog("0", "TradeFluxRecord", "Import"); return "success"; } #endregion #region 导出Excel /// /// 导出Excel /// /// public JsonResult ExportExcel(TradeFluxRecord data, string TradeStatusSelect, string ProductTypeSelect) { Dictionary Fields = new Dictionary(); Fields.Add("MerNo", "1"); //商户编号 Fields.Add("KqTradeSeq", "1"); //快钱交易流水号 string condition = " and Status>-1"; //交易状态 if (!string.IsNullOrEmpty(TradeStatusSelect)) { condition += " and TradeStatus=" + TradeStatusSelect; } //产品类型 if (!string.IsNullOrEmpty(ProductTypeSelect)) { condition += " and ProductType=" + ProductTypeSelect; } Dictionary obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.SpTables).IndexData("TradeFluxRecord", Fields, "Id desc", "0", 1, 20000, condition, "TradeSerialNo,MerNo,TradeAmount,TradeStatus,TradeDate,TradeTime,BankCardType,DigAmt,BankCardNo,FeeAmount,KqTradeSeq,ProductType,AgentNo", false); List> diclist = obj["data"] as List>; foreach (Dictionary dic in diclist) { //交易状态 string TradeStatus = dic["TradeStatus"].ToString(); if (TradeStatus == "1") dic["TradeStatus"] = "成功"; if (TradeStatus == "2") dic["TradeStatus"] = "失败"; if (TradeStatus == "") dic["TradeStatus"] = ""; //银行卡类型 string BankCardType = dic["BankCardType"].ToString(); if (BankCardType == "0001") dic["BankCardType"] = "贷记卡"; if (BankCardType == "0002") dic["BankCardType"] = "借记卡"; if (BankCardType == "") dic["BankCardType"] = ""; //产品类型 string ProductType = dic["ProductType"].ToString(); if (ProductType == "KYSPOS") dic["ProductType"] = "快益刷"; if (ProductType == "KPOS") dic["ProductType"] = "快联盟大POS"; if (ProductType == "SIGNPOS") dic["ProductType"] = "快联盟电签POS"; if (ProductType == "SUPPOS") dic["ProductType"] = "超级Mpos"; if (ProductType == "") dic["ProductType"] = ""; } Dictionary result = new Dictionary(); result.Add("Status", "1"); result.Add("Info", "Excel报表-" + DateTime.Now.ToString("yyyy-MM-ddTHH:mm:ss") + ".xlsx"); result.Add("Obj", diclist); Dictionary ReturnFields = new Dictionary(); ReturnFields.Add("TradeSerialNo", "交易单号"); ReturnFields.Add("MerNo", "商户编号"); ReturnFields.Add("TradeAmount", "交易金额"); ReturnFields.Add("TradeStatus", "交易状态"); ReturnFields.Add("TradeDate", "交易日期"); ReturnFields.Add("TradeTime", "交易时间"); ReturnFields.Add("BankCardType", "银行卡类型"); ReturnFields.Add("DigAmt", "挖款金额"); ReturnFields.Add("BankCardNo", "交易卡号"); ReturnFields.Add("FeeAmount", "手续费"); ReturnFields.Add("KqTradeSeq", "快钱交易流水号"); ReturnFields.Add("ProductType", "产品类型"); ReturnFields.Add("AgentNo", "代理商编号"); result.Add("Fields", ReturnFields); AddSysLog("0", "TradeFluxRecord", "ExportExcel"); return Json(result); } #endregion } }