/* * 退款申请 */ 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.Models; using Library; using LitJson; using MySystemLib; namespace MySystem.Areas.Admin.Controllers { [Area("Admin")] [Route("Admin/[controller]/[action]")] public class OrderRefundController : BaseController { public OrderRefundController(IHttpContextAccessor accessor, ILogger logger, IOptions setting) : base(accessor, logger, setting) { OtherMySqlConn.connstr = ConfigurationManager.AppSettings["SqlConnStr"].ToString(); } #region 退款申请列表 /// /// 根据条件查询退款申请列表 /// /// public IActionResult Index(OrderRefund data, string right) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; string Condition = ""; Condition += "Reason:\"" + data.Reason + "\","; Condition += "Mobile:\"" + data.Mobile + "\","; Condition += "GoodStatus:\"" + data.GoodStatus + "\","; if (!string.IsNullOrEmpty(Condition)) { Condition = Condition.TrimEnd(','); Condition = ", where: {" + Condition + "}"; } ViewBag.Condition = Condition; return View(); } #endregion #region 根据条件查询退款申请列表 /// /// 退款申请列表 /// /// public JsonResult IndexData(OrderRefund data, int page = 1, int limit = 30) { Dictionary OrderRefundReasonDic = new OrderDictionary().getOrderRefundReasonDic(); Dictionary ErpCompanysDic = new OrderDictionary().getErpCompanysDic(); Dictionary Fields = new Dictionary(); Fields.Add("Reason", "1"); //退款原因 Fields.Add("Mobile", "2"); //申请人手机号 Fields.Add("GoodStatus", "1"); //货物状态 Dictionary obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("OrderRefund", Fields, "Id desc", "False", page, limit); List> diclist = obj["data"] as List>; foreach (Dictionary dic in diclist) { dic["Reason"] = new DictionaryClass().getDictionaryNameByKey(OrderRefundReasonDic, dic["Reason"].ToString()); dic["ErpCompany"] = new DictionaryClass().getDictionaryNameByKey(ErpCompanysDic, dic["ErpCompany"].ToString()); dic["GoodStatus"] = dic["GoodStatus"].ToString() == "1" ? "未收到货" : "已收到货"; dic["Status"] = dic["Status"].ToString() == "1" ? "已处理" : "未处理"; } return Json(obj); } #endregion #region 增加退款申请 /// /// 增加或修改退款申请信息 /// /// public IActionResult Add(string right) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; return View(); } #endregion #region 增加退款申请 /// /// 增加或修改退款申请信息 /// /// [HttpPost] public string Add(OrderRefund data) { Dictionary Fields = new Dictionary(); Fields.Add("Reason", data.Reason); //退款原因 Fields.Add("Amount", data.Amount); //退款金额 Fields.Add("Contents", data.Contents); //补充说明 Fields.Add("Mobile", data.Mobile); //申请人手机号 Fields.Add("GoodStatus", data.GoodStatus); //货物状态 Fields.Add("Photos", data.Photos); //凭证 Fields.Add("ErpCompany", data.ErpCompany); //快递公司 Fields.Add("ErpCode", data.ErpCode); //快递运单号 Fields.Add("SeoTitle", data.SeoTitle); Fields.Add("SeoKeyword", data.SeoKeyword); Fields.Add("SeoDescription", data.SeoDescription); int Id = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Add("OrderRefund", Fields, 0); AddSysLog(data.Id.ToString(), "OrderRefund", "add"); db.SaveChanges(); return "success"; } #endregion #region 修改退款申请 /// /// 增加或修改退款申请信息 /// /// public IActionResult Edit(string right, int Id = 0) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; OrderRefund editData = db.OrderRefund.FirstOrDefault(m => m.Id == Id) ?? new OrderRefund(); ViewBag.data = editData; string[] idlist = editData.ProductId.Split(','); List ids = new List(); foreach (string idstring in idlist) { ids.Add(int.Parse(idstring)); } List products = db.OrderProduct.Where(m => ids.Contains(m.Id)).ToList(); ViewBag.products = products; return View(); } #endregion #region 修改退款申请 /// /// 增加或修改退款申请信息 /// /// [HttpPost] public string Edit(OrderRefund data) { Dictionary Fields = new Dictionary(); // Fields.Add("Reason", data.Reason); //退款原因 // Fields.Add("Amount", data.Amount); //退款金额 // Fields.Add("Contents", data.Contents); //补充说明 // Fields.Add("Mobile", data.Mobile); //申请人手机号 // Fields.Add("GoodStatus", data.GoodStatus); //货物状态 // Fields.Add("Photos", data.Photos); //凭证 // Fields.Add("ErpCompany", data.ErpCompany); //快递公司 // Fields.Add("ErpCode", data.ErpCode); //快递运单号 // Fields.Add("SeoTitle", data.SeoTitle); // Fields.Add("SeoKeyword", data.SeoKeyword); // Fields.Add("SeoDescription", data.SeoDescription); OrderRefund refund = db.OrderRefund.FirstOrDefault(m => m.Id == data.Id); if (refund != null) { if (refund.Status == 1) { return "已经处理过了"; } refund.Status = 1; } Fields.Add("Status", 1); Orders order = db.Orders.FirstOrDefault(m => m.Id == data.OrderId); if (order != null) { order.Status = 6; string result = ""; PublicAccountSet set = db.PublicAccountSet.FirstOrDefault() ?? new PublicAccountSet(); if (order.PayMode == 1) { result = new Alipay.AlipayPublicClass(_accessor.HttpContext).Refund(set.AlipayAppId, set.AlipayPrivateKey, set.AlipayPublicKey, order.OrderNo, order.ActualPay); } else if (order.PayMode == 2) { result = new WeChat.WeChatPublicClass(_accessor.HttpContext).Refund(set.WeChatAppId, set.WeChatMchId, order.OrderNo, order.TradeNo, order.ActualPay, set.WeChatPayKey, function.getPath("/Public/Cert/WeChat/apiclient_cert.p12")); } if (result.StartsWith("success|")) { int OrderCount = db.OrderForNo.FirstOrDefault(m=>m.OrderNo == order.OrderNo).OrderIds.Split(',').Length; if (order.CouponId > 0 && OrderCount == 1) { Coupons coupon = db.Coupons.FirstOrDefault(m => m.Id == order.CouponId); if (coupon != null) { if (coupon.IsReUse == 0) { CouponsForUser couponForUser = db.CouponsForUser.FirstOrDefault(m => m.UserId == order.UserId && m.CouponId == order.CouponId && m.IsUse == 1); if (couponForUser != null) { couponForUser.IsLock = 0; couponForUser.IsUse = 0; } } } } } } new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("OrderRefund", Fields, data.Id); AddSysLog(data.Id.ToString(), "OrderRefund", "update"); db.SaveChanges(); return "success"; } #endregion #region 删除退款申请信息 /// /// 删除退款申请信息 /// /// public string Delete(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "OrderRefund", "del"); foreach (string subid in idlist) { int id = int.Parse(subid); new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Delete("OrderRefund", id); } db.SaveChanges(); return "success"; } #endregion #region 开启 /// /// 开启 /// /// public string Open(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "OrderRefund", "open"); foreach (string subid in idlist) { int id = int.Parse(subid); Dictionary Fields = new Dictionary(); Fields.Add("Status", 1); new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("OrderRefund", Fields, id); } db.SaveChanges(); return "success"; } #endregion #region 关闭 /// /// 关闭 /// /// public string Close(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "OrderRefund", "close"); foreach (string subid in idlist) { int id = int.Parse(subid); Dictionary Fields = new Dictionary(); Fields.Add("Status", 0); new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("OrderRefund", Fields, id); } db.SaveChanges(); return "success"; } #endregion #region 排序 /// /// 排序 /// /// public string Sort(int Id, int Sort) { new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Sort("OrderRefund", Sort, Id); AddSysLog(Id.ToString(), "OrderRefund", "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]; db.OrderRefund.Add(new OrderRefund() { CreateDate = DateTime.Now, UpdateDate = DateTime.Now, }); db.SaveChanges(); } AddSysLog("0", "OrderRefund", "Import"); return "success"; } #endregion #region 导出Excel /// /// 导出Excel /// /// public JsonResult ExportExcel(OrderRefund data) { Dictionary Fields = new Dictionary(); Fields.Add("Reason", "1"); //退款原因 Fields.Add("Mobile", "2"); //申请人手机号 Fields.Add("GoodStatus", "1"); //货物状态 Dictionary obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("OrderRefund", Fields, "Id desc", "False", 1, 20000, "", "", false); List> diclist = obj["data"] as List>; 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(); result.Add("Fields", ReturnFields); AddSysLog("0", "OrderRefund", "ExportExcel"); return Json(result); } #endregion } }