/* * 创客预设职级 */ 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 UserRankWhiteController : BaseController { public UserRankWhiteController(IHttpContextAccessor accessor, ILogger logger, IOptions setting) : base(accessor, logger, setting) { OtherMySqlConn.connstr = ConfigurationManager.AppSettings["SqlConnStr"].ToString(); } #region 创客预设职级列表 /// /// 根据条件查询创客预设职级列表 /// /// public IActionResult Index(UserRankWhite data, string right) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; return View(); } #endregion #region 根据条件查询创客预设职级列表 /// /// 创客预设职级列表 /// /// public JsonResult IndexData(UserRankWhite data, string MakerCode, string RealName, string StatusSelect, int page = 1, int limit = 30) { Dictionary Fields = new Dictionary(); string condition = " and Status>-1"; //创客编号 if (!string.IsNullOrEmpty(MakerCode)) { condition += " and UserId in (select UserId from UserForMakerCode where MakerCode='" + MakerCode + "')"; } //创客名称 if (!string.IsNullOrEmpty(RealName)) { condition += " and UserId in (select UserId from UserForRealName where RealName='" + RealName + "')"; } //状态 if (!string.IsNullOrEmpty(StatusSelect)) { condition += " and Status=" + StatusSelect; } Dictionary obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("UserRankWhite", Fields, "Id desc", "0", page, limit, condition); List> diclist = obj["data"] as List>; foreach (Dictionary dic in diclist) { dic["Rank"] = RelationClass.GetUserLevelSetInfo(int.Parse(dic["Rank"].ToString())); int UserId = int.Parse(dic["UserId"].ToString()); Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users(); dic["MakerCode"] = user.MakerCode; dic["RealName"] = user.RealName; if (user.ParentUserId > 0) { Users puser = db.Users.FirstOrDefault(m => m.Id == user.ParentUserId) ?? new Users(); dic["ParentMakerCode"] = puser.MakerCode; dic["ParentRealName"] = puser.RealName; } if (!string.IsNullOrEmpty(user.ParentNav)) { int TopId = int.Parse(user.ParentNav.Trim(',').Replace(",,", ",").Split(',')[0]); Users tuser = db.Users.FirstOrDefault(m => m.Id == TopId) ?? new Users(); dic["TopMakerCode"] = tuser.MakerCode; dic["TopRealName"] = tuser.RealName; } 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(UserRankWhite data, string MakerCode) { bool check = db.UserForMakerCode.Any(m => m.MakerCode == MakerCode); if (!check) { return "创客编号不存在"; } Dictionary Fields = new Dictionary(); UserForMakerCode user = db.UserForMakerCode.FirstOrDefault(m => m.MakerCode == MakerCode) ?? new UserForMakerCode(); check = db.UserRankWhite.Any(m => m.UserId == user.UserId); if (check) { return "已添加过此创客编号,请勿重复添加"; } Fields.Add("UserId", user.UserId); Fields.Add("Rank", data.Rank); Fields.Add("Status", data.Status); Fields.Add("SeoTitle", data.SeoTitle); Fields.Add("SeoKeyword", data.SeoKeyword); Fields.Add("SeoDescription", data.SeoDescription); int Id = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Add("UserRankWhite", Fields, 0); AddSysLog(data.Id.ToString(), "UserRankWhite", "add"); db.SaveChanges(); UserRank rank = RedisDbconn.Instance.Get("UserRank:" + user.UserId); if (rank != null) { rank.WhiteRank = data.Rank; RedisDbconn.Instance.Set("UserRank:" + user.UserId, rank); } return "success"; } #endregion #region 修改创客预设职级 /// /// 增加或修改创客预设职级信息 /// /// public IActionResult Edit(string right, int Id = 0) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; UserRankWhite editData = db.UserRankWhite.FirstOrDefault(m => m.Id == Id) ?? new UserRankWhite(); ViewBag.data = editData; Users user = db.Users.FirstOrDefault(m => m.Id == editData.UserId) ?? new Users(); ViewBag.MakerCode = user.MakerCode; ViewBag.RealName = user.RealName; return View(); } #endregion #region 修改创客预设职级 /// /// 增加或修改创客预设职级信息 /// /// [HttpPost] public string Edit(UserRankWhite data, string MakerCode) { Dictionary Fields = new Dictionary(); Fields.Add("Rank", data.Rank); Fields.Add("Status", data.Status); new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("UserRankWhite", Fields, data.Id); AddSysLog(data.Id.ToString(), "UserRankWhite", "update"); db.SaveChanges(); UserRankWhite white = db.UserRankWhite.FirstOrDefault(m => m.Id == data.Id); if (white != null) { UserRank rank = RedisDbconn.Instance.Get("UserRank:" + white.UserId); if (rank != null) { rank.WhiteRank = data.Rank; RedisDbconn.Instance.Set("UserRank:" + white.UserId, rank); } } return "success"; } #endregion #region 删除创客预设职级信息 /// /// 删除创客预设职级信息 /// /// public string Delete(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "UserRankWhite", "del"); 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("UserRankWhite", Fields, id); } db.SaveChanges(); return "success"; } #endregion #region 开启 /// /// 开启 /// /// public string Open(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "UserRankWhite", "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("UserRankWhite", Fields, id); } db.SaveChanges(); return "success"; } #endregion #region 关闭 /// /// 关闭 /// /// public string Close(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "UserRankWhite", "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("UserRankWhite", Fields, id); } db.SaveChanges(); return "success"; } #endregion #region 排序 /// /// 排序 /// /// public string Sort(int Id, int Sort) { new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Sort("UserRankWhite", Sort, Id); AddSysLog(Id.ToString(), "UserRankWhite", "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.UserRankWhite.Add(new UserRankWhite() { CreateDate = DateTime.Now, UpdateDate = DateTime.Now, }); db.SaveChanges(); } AddSysLog("0", "UserRankWhite", "Import"); return "success"; } #endregion #region 导出Excel /// /// 导出Excel /// /// public JsonResult ExportExcel(UserRankWhite data, string MakerCode, string RealName, string StatusSelect) { Dictionary Fields = new Dictionary(); string condition = " and Status>-1"; //创客编号 if (!string.IsNullOrEmpty(MakerCode)) { condition += " and UserId in (select UserId from UserForMakerCode where MakerCode='" + MakerCode + "')"; } //创客名称 if (!string.IsNullOrEmpty(RealName)) { condition += " and UserId in (select UserId from UserForRealName where RealName='" + RealName + "')"; } //状态 if (!string.IsNullOrEmpty(StatusSelect)) { condition += " and Status=" + StatusSelect; } Dictionary obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("UserRankWhite", Fields, "Id desc", "0", 1, 20000, condition, "UserId,Rank,Status,CreateDate", false); List> diclist = obj["data"] as List>; foreach (Dictionary dic in diclist) { dic["Rank"] = RelationClass.GetUserLevelSetInfo(int.Parse(dic["Rank"].ToString())); int UserId = int.Parse(dic["UserId"].ToString()); Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users(); dic["MakerCode"] = user.MakerCode; dic["RealName"] = user.RealName; if (user.ParentUserId > 0) { Users puser = db.Users.FirstOrDefault(m => m.Id == user.ParentUserId) ?? new Users(); dic["ParentMakerCode"] = puser.MakerCode; dic["ParentRealName"] = puser.RealName; } if (!string.IsNullOrEmpty(user.ParentNav)) { int TopId = int.Parse(user.ParentNav.Trim(',').Replace(",,", ",").Split(',')[0]); Users tuser = db.Users.FirstOrDefault(m => m.Id == TopId) ?? new Users(); dic["TopMakerCode"] = tuser.MakerCode; dic["TopRealName"] = tuser.RealName; } dic["Status"] = dic["Status"].ToString() == "1" ? "有效" : "无效"; dic.Remove("UserId"); } 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("MakerCode", "创客编号"); ReturnFields.Add("RealName", "创客姓名"); ReturnFields.Add("ParentMakerCode", "上级创客编号"); ReturnFields.Add("ParentRealName", "上级创客名称"); ReturnFields.Add("TopMakerCode", "顶级创客编号"); ReturnFields.Add("TopRealName", "顶级创客名称"); ReturnFields.Add("Rank", "等级名称"); ReturnFields.Add("Status", "有效状态"); ReturnFields.Add("CreateDate", "创建时间"); result.Add("Fields", ReturnFields); AddSysLog("0", "UserRankWhite", "ExportExcel"); return Json(result); } #endregion } }