ProductFareTempController.cs 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384
  1. /*
  2. * 商品运费模板
  3. */
  4. using System;
  5. using System.Web;
  6. using System.Collections.Generic;
  7. using System.Diagnostics;
  8. using System.Linq;
  9. using System.Threading.Tasks;
  10. using Microsoft.AspNetCore.Mvc;
  11. using Microsoft.AspNetCore.Http;
  12. using Microsoft.Extensions.Logging;
  13. using Microsoft.Extensions.Options;
  14. using MySystem.Models;
  15. using Library;
  16. using LitJson;
  17. using MySystemLib;
  18. namespace MySystem.Areas.Admin.Controllers
  19. {
  20. [Area("Admin")]
  21. [Route("Admin/[controller]/[action]")]
  22. public class ProductFareTempController : BaseController
  23. {
  24. public ProductFareTempController(IHttpContextAccessor accessor, ILogger<BaseController> logger, IOptions<Setting> setting) : base(accessor, logger, setting)
  25. {
  26. OtherMySqlConn.connstr = ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  27. }
  28. #region 商品运费模板列表
  29. /// <summary>
  30. /// 根据条件查询商品运费模板列表
  31. /// </summary>
  32. /// <returns></returns>
  33. public IActionResult Index(ProductFareTemp data, string right, string MerchantId)
  34. {
  35. ViewBag.RightInfo = RightInfo;
  36. ViewBag.right = right;
  37. ViewBag.MerchantId = MerchantId;
  38. string Condition = "";
  39. Condition += "Name:\"" + data.Name + "\",";
  40. Condition += "MeterMode:\"" + data.MeterMode + "\",";
  41. Condition += "TransportMode:\"" + data.TransportMode + "\",";
  42. if (!string.IsNullOrEmpty(Condition))
  43. {
  44. Condition = Condition.TrimEnd(',');
  45. Condition = ", where: {" + Condition + "}";
  46. }
  47. ViewBag.Condition = Condition;
  48. return View();
  49. }
  50. #endregion
  51. #region 根据条件查询商品运费模板列表
  52. /// <summary>
  53. /// 商品运费模板列表
  54. /// </summary>
  55. /// <returns></returns>
  56. public JsonResult IndexData(ProductFareTemp data, int page = 1, int limit = 30)
  57. {
  58. Dictionary<string, string> Fields = new Dictionary<string, string>();
  59. Fields.Add("MerchantId", "1");
  60. Fields.Add("Name", "2"); //名称
  61. Fields.Add("MeterMode", "1"); //计价方式
  62. Fields.Add("TransportMode", "1"); //运送方式
  63. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("ProductFareTemp", Fields, "Id desc", "False", page, limit);
  64. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  65. foreach (Dictionary<string, object> dic in diclist)
  66. {
  67. dic["IsFree"] = dic["IsFree"].ToString() == "1" ? "是" : "否";
  68. }
  69. return Json(obj);
  70. }
  71. #endregion
  72. #region 增加商品运费模板
  73. /// <summary>
  74. /// 增加或修改商品运费模板信息
  75. /// </summary>
  76. /// <returns></returns>
  77. public IActionResult Add(string right, string MerchantId)
  78. {
  79. ViewBag.RightInfo = RightInfo;
  80. ViewBag.right = right;
  81. ViewBag.MerchantId = MerchantId;
  82. return View();
  83. }
  84. #endregion
  85. #region 增加商品运费模板
  86. /// <summary>
  87. /// 增加或修改商品运费模板信息
  88. /// </summary>
  89. /// <returns></returns>
  90. [HttpPost]
  91. public string Add(ProductFareTemp data)
  92. {
  93. Dictionary<string, object> Fields = new Dictionary<string, object>();
  94. Fields.Add("MerchantId", data.MerchantId);
  95. Fields.Add("Name", data.Name); //名称
  96. Fields.Add("SendAreas", data.SendAreas); //发货地区
  97. Fields.Add("SendAddress", data.SendAddress); //发货地址
  98. Fields.Add("SendDate", data.SendDate); //发货时间
  99. Fields.Add("IsFree", data.IsFree); //是否包邮
  100. Fields.Add("MeterMode", data.MeterMode); //计价方式
  101. Fields.Add("TransportMode", data.TransportMode); //运送方式
  102. Fields.Add("FirstAmount", data.FirstAmount); //首件数量
  103. Fields.Add("FirstFee", data.FirstFee); //首件费用
  104. Fields.Add("MoreAmount", data.MoreAmount); //续件数量
  105. Fields.Add("MoreFee", data.MoreFee); //续件费用
  106. Fields.Add("SeoDescription", data.SeoDescription);
  107. int Id = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Add("ProductFareTemp", Fields, 0);
  108. JsonData jsonObj = JsonMapper.ToObject(data.SeoDescription);
  109. for (int i = 0; i < jsonObj.Count; i++)
  110. {
  111. string area = jsonObj[i]["area"].ToString();
  112. decimal firstAmount = decimal.Parse(function.CheckNum(jsonObj[i]["firstAmount"].ToString()));
  113. decimal firstFee = decimal.Parse(function.CheckNum(jsonObj[i]["firstFee"].ToString()));
  114. decimal moreAmount = decimal.Parse(function.CheckNum(jsonObj[i]["moreAmount"].ToString()));
  115. decimal moreFee = decimal.Parse(function.CheckNum(jsonObj[i]["moreFee"].ToString()));
  116. db.ProductFareAreas.Add(new ProductFareAreas() {
  117. CreateDate = DateTime.Now,
  118. UpdateDate = DateTime.Now,
  119. MerchantId = data.MerchantId,
  120. TemplateId = Id,
  121. Areas = area,
  122. FirstAmount = firstAmount,
  123. FirstFee = firstFee,
  124. MoreAmount = moreAmount,
  125. MoreFee = moreFee,
  126. });
  127. }
  128. AddSysLog(data.Id.ToString(), "ProductFareTemp", "add");
  129. db.SaveChanges();
  130. return "success";
  131. }
  132. #endregion
  133. #region 修改商品运费模板
  134. /// <summary>
  135. /// 增加或修改商品运费模板信息
  136. /// </summary>
  137. /// <returns></returns>
  138. public IActionResult Edit(string right, string MerchantId, int Id = 0)
  139. {
  140. ViewBag.RightInfo = RightInfo;
  141. ViewBag.right = right;
  142. ViewBag.MerchantId = MerchantId;
  143. ProductFareTemp editData = db.ProductFareTemp.FirstOrDefault(m => m.Id == Id) ?? new ProductFareTemp();
  144. ViewBag.data = editData;
  145. return View();
  146. }
  147. #endregion
  148. #region 修改商品运费模板
  149. /// <summary>
  150. /// 增加或修改商品运费模板信息
  151. /// </summary>
  152. /// <returns></returns>
  153. [HttpPost]
  154. public string Edit(ProductFareTemp data)
  155. {
  156. Dictionary<string, object> Fields = new Dictionary<string, object>();
  157. Fields.Add("Name", data.Name); //名称
  158. Fields.Add("SendAreas", data.SendAreas); //发货地区
  159. Fields.Add("SendAddress", data.SendAddress); //发货地址
  160. Fields.Add("SendDate", data.SendDate); //发货时间
  161. Fields.Add("IsFree", data.IsFree); //是否包邮
  162. Fields.Add("MeterMode", data.MeterMode); //计价方式
  163. Fields.Add("TransportMode", data.TransportMode); //运送方式
  164. Fields.Add("FirstAmount", data.FirstAmount); //首件数量
  165. Fields.Add("FirstFee", data.FirstFee); //首件费用
  166. Fields.Add("MoreAmount", data.MoreAmount); //续件数量
  167. Fields.Add("MoreFee", data.MoreFee); //续件费用
  168. Fields.Add("SeoDescription", data.SeoDescription);
  169. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("ProductFareTemp", Fields, data.Id);
  170. JsonData jsonObj = JsonMapper.ToObject(data.SeoDescription);
  171. for (int i = 0; i < jsonObj.Count; i++)
  172. {
  173. string area = jsonObj[i]["area"].ToString();
  174. decimal firstAmount = decimal.Parse(function.CheckNum(jsonObj[i]["firstAmount"].ToString()));
  175. decimal firstFee = decimal.Parse(function.CheckNum(jsonObj[i]["firstFee"].ToString()));
  176. decimal moreAmount = decimal.Parse(function.CheckNum(jsonObj[i]["moreAmount"].ToString()));
  177. decimal moreFee = decimal.Parse(function.CheckNum(jsonObj[i]["moreFee"].ToString()));
  178. ProductFareAreas check = db.ProductFareAreas.FirstOrDefault(m => m.MerchantId == data.MerchantId && m.TemplateId == data.Id && m.Areas == area);
  179. if (check == null)
  180. {
  181. db.ProductFareAreas.Add(new ProductFareAreas()
  182. {
  183. CreateDate = DateTime.Now,
  184. UpdateDate = DateTime.Now,
  185. MerchantId = data.MerchantId,
  186. TemplateId = data.Id,
  187. Areas = area,
  188. FirstAmount = firstAmount,
  189. FirstFee = firstFee,
  190. MoreAmount = moreAmount,
  191. MoreFee = moreFee,
  192. });
  193. }
  194. else
  195. {
  196. check.UpdateDate = DateTime.Now;
  197. check.Areas = area;
  198. check.FirstAmount = firstAmount;
  199. check.FirstFee = firstFee;
  200. check.MoreAmount = moreAmount;
  201. check.MoreFee = moreFee;
  202. }
  203. }
  204. AddSysLog(data.Id.ToString(), "ProductFareTemp", "update");
  205. db.SaveChanges();
  206. return "success";
  207. }
  208. #endregion
  209. #region 删除商品运费模板信息
  210. /// <summary>
  211. /// 删除商品运费模板信息
  212. /// </summary>
  213. /// <returns></returns>
  214. public string Delete(string Id)
  215. {
  216. string[] idlist = Id.Split(new char[] { ',' });
  217. AddSysLog(Id, "ProductFareTemp", "del");
  218. foreach (string subid in idlist)
  219. {
  220. int id = int.Parse(subid);
  221. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Delete("ProductFareTemp", id);
  222. }
  223. db.SaveChanges();
  224. return "success";
  225. }
  226. #endregion
  227. #region 开启
  228. /// <summary>
  229. /// 开启
  230. /// </summary>
  231. /// <returns></returns>
  232. public string Open(string Id)
  233. {
  234. string[] idlist = Id.Split(new char[] { ',' });
  235. AddSysLog(Id, "ProductFareTemp", "open");
  236. foreach (string subid in idlist)
  237. {
  238. int id = int.Parse(subid);
  239. Dictionary<string, object> Fields = new Dictionary<string, object>();
  240. Fields.Add("Status", 1);
  241. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("ProductFareTemp", Fields, id);
  242. }
  243. db.SaveChanges();
  244. return "success";
  245. }
  246. #endregion
  247. #region 关闭
  248. /// <summary>
  249. /// 关闭
  250. /// </summary>
  251. /// <returns></returns>
  252. public string Close(string Id)
  253. {
  254. string[] idlist = Id.Split(new char[] { ',' });
  255. AddSysLog(Id, "ProductFareTemp", "close");
  256. foreach (string subid in idlist)
  257. {
  258. int id = int.Parse(subid);
  259. Dictionary<string, object> Fields = new Dictionary<string, object>();
  260. Fields.Add("Status", 0);
  261. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("ProductFareTemp", Fields, id);
  262. }
  263. db.SaveChanges();
  264. return "success";
  265. }
  266. #endregion
  267. #region 排序
  268. /// <summary>
  269. /// 排序
  270. /// </summary>
  271. /// <param name="Id"></param>
  272. public string Sort(int Id, int Sort)
  273. {
  274. new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Sort("ProductFareTemp", Sort, Id);
  275. AddSysLog(Id.ToString(), "ProductFareTemp", "sort");
  276. return "success";
  277. }
  278. #endregion
  279. #region 导入数据
  280. /// <summary>
  281. /// 导入数据
  282. /// </summary>
  283. /// <param name="ExcelData"></param>
  284. public string Import(string ExcelData)
  285. {
  286. ExcelData = HttpUtility.UrlDecode(ExcelData);
  287. JsonData list = JsonMapper.ToObject(ExcelData);
  288. for (int i = 1; i < list.Count; i++)
  289. {
  290. JsonData dr = list[i];
  291. db.ProductFareTemp.Add(new ProductFareTemp()
  292. {
  293. CreateDate = DateTime.Now,
  294. UpdateDate = DateTime.Now,
  295. });
  296. db.SaveChanges();
  297. }
  298. AddSysLog("0", "ProductFareTemp", "Import");
  299. return "success";
  300. }
  301. #endregion
  302. #region 导出Excel
  303. /// <summary>
  304. /// 导出Excel
  305. /// </summary>
  306. /// <returns></returns>
  307. public JsonResult ExportExcel(ProductFareTemp data)
  308. {
  309. Dictionary<string, string> Fields = new Dictionary<string, string>();
  310. Fields.Add("Name", "2"); //名称
  311. Fields.Add("MeterMode", "1"); //计价方式
  312. Fields.Add("TransportMode", "1"); //运送方式
  313. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("ProductFareTemp", Fields, "Id desc", "False", 1, 20000, "", "", false);
  314. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  315. Dictionary<string, object> result = new Dictionary<string, object>();
  316. result.Add("Status", "1");
  317. result.Add("Info", "Excel报表-" + DateTime.Now.ToString("yyyy-MM-ddTHH:mm:ss") + ".xlsx");
  318. result.Add("Obj", diclist);
  319. Dictionary<string, object> ReturnFields = new Dictionary<string, object>();
  320. result.Add("Fields", ReturnFields);
  321. AddSysLog("0", "ProductFareTemp", "ExportExcel");
  322. return Json(result);
  323. }
  324. #endregion
  325. public JsonResult GetTemplate(int MerchantId)
  326. {
  327. List<ProductFareTemp> list = db.ProductFareTemp.Where(m => m.MerchantId == MerchantId).OrderByDescending(m => m.Sort).ThenByDescending(m => m.Id).ToList();
  328. return Json(list);
  329. }
  330. }
  331. }