/* * 小程序版本 */ 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 MySystem; using MySystemLib; namespace MySystem.Areas.Admin.Controllers { [Area("Admin")] [Route("Admin/[controller]/[action]")] public class ProjectVersionController : BaseController { public ProjectVersionController(IHttpContextAccessor accessor, ILogger logger, IOptions setting) : base(accessor, logger, setting) { OtherMySqlConn.connstr = ConfigurationManager.AppSettings["SqlConnStr"].ToString(); } #region 小程序版本列表 /// /// 根据条件查询小程序版本列表 /// /// public IActionResult Index(ProjectVersion data, string right) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; return View(); } #endregion #region 根据条件查询小程序版本列表 /// /// 小程序版本列表 /// /// public JsonResult IndexData(ProjectVersion data, string ProjectIdSelect, string UserIdRealName, string UserIdMobile, string DeveloperIdNickName, string DeveloperIdRealName, string DeveloperIdMobile, int page = 1, int limit = 30) { Dictionary Fields = new Dictionary(); Fields.Add("CreateDate", "3"); //时间 string condition = " and Status>-1"; //小程序项目 if (!string.IsNullOrEmpty(ProjectIdSelect)) { condition += " and ProjectId=" + ProjectIdSelect; } //所属用户真实姓名 if (!string.IsNullOrEmpty(UserIdRealName)) { condition += " and UserId in (select UserId from UsersForRealName where RealName='" + UserIdRealName + "')"; } //所属用户手机号 if (!string.IsNullOrEmpty(UserIdMobile)) { condition += " and UserId in (select UserId from UsersForMobile where Mobile='" + UserIdMobile + "')"; } //开发者昵称 if (!string.IsNullOrEmpty(DeveloperIdNickName)) { condition += " and DeveloperId in (select DeveloperId from DevelopersForNickName where NickName='" + DeveloperIdNickName + "')"; } //开发者真实姓名 if (!string.IsNullOrEmpty(DeveloperIdRealName)) { condition += " and DeveloperId in (select DeveloperId from DevelopersForRealName where RealName='" + DeveloperIdRealName + "')"; } //开发者手机号 if (!string.IsNullOrEmpty(DeveloperIdMobile)) { condition += " and DeveloperId in (select DeveloperId from DevelopersForMobile where Mobile='" + DeveloperIdMobile + "')"; } Dictionary obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("ProjectVersion", Fields, "Id desc", "0", page, limit, condition); List> diclist = obj["data"] as List>; foreach (Dictionary dic in diclist) { //小程序项目 // dic["ProjectId"] = RelationClass.GetProjectsInfo(int.Parse(dic["ProjectId"].ToString())); //所属用户 int UserId = int.Parse(function.CheckInt(dic["UserId"].ToString())); Users userid_Users = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users(); dic["UserIdRealName"] = userid_Users.RealName; dic["UserIdMobile"] = userid_Users.Mobile; dic.Remove("UserId"); //开发者 int DeveloperId = int.Parse(function.CheckInt(dic["DeveloperId"].ToString())); Developers developerid_Developers = db.Developers.FirstOrDefault(m => m.Id == DeveloperId) ?? new Developers(); dic["DeveloperIdNickName"] = developerid_Developers.NickName; dic["DeveloperIdRealName"] = developerid_Developers.RealName; dic["DeveloperIdMobile"] = developerid_Developers.Mobile; dic.Remove("DeveloperId"); } return Json(obj); } #endregion #region 增加小程序版本 /// /// 增加或修改小程序版本信息 /// /// public IActionResult Add(string right) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; return View(); } #endregion #region 增加小程序版本 /// /// 增加或修改小程序版本信息 /// /// [HttpPost] public string Add(ProjectVersion data) { Dictionary Fields = new Dictionary(); Fields.Add("ProjectId", data.ProjectId); //小程序项目 Fields.Add("UserId", data.UserId); //所属用户 Fields.Add("DeveloperId", data.DeveloperId); //开发者 Fields.Add("VerNum", data.VerNum); //版本号 Fields.Add("UpdateNote", data.UpdateNote); //更新说明 Fields.Add("ReturnNote", data.ReturnNote); //反馈意见 Fields.Add("FilePath", data.FilePath); //模板文件路径 Fields.Add("SeoTitle", data.SeoTitle); Fields.Add("SeoKeyword", data.SeoKeyword); Fields.Add("SeoDescription", data.SeoDescription); int Id = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Add("ProjectVersion", Fields, 0); AddSysLog(data.Id.ToString(), "ProjectVersion", "add"); db.SaveChanges(); return "success"; } #endregion #region 修改小程序版本 /// /// 增加或修改小程序版本信息 /// /// public IActionResult Edit(string right, int Id = 0) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; ProjectVersion editData = db.ProjectVersion.FirstOrDefault(m => m.Id == Id) ?? new ProjectVersion(); ViewBag.data = editData; return View(); } #endregion #region 修改小程序版本 /// /// 增加或修改小程序版本信息 /// /// [HttpPost] public string Edit(ProjectVersion data) { Dictionary Fields = new Dictionary(); // Fields.Add("ProjectId", data.ProjectId); //小程序项目 // Fields.Add("UserId", data.UserId); //所属用户 // Fields.Add("DeveloperId", data.DeveloperId); //开发者 Fields.Add("VerNum", data.VerNum); //版本号 Fields.Add("VersionNo", data.VersionNo); // Fields.Add("UpdateNote", data.UpdateNote); //更新说明 // Fields.Add("ReturnNote", data.ReturnNote); //反馈意见 Fields.Add("FilePath", data.FilePath); //模板文件路径 Fields.Add("SeoTitle", data.SeoTitle); Fields.Add("SeoKeyword", data.SeoKeyword); Fields.Add("SeoDescription", data.SeoDescription); new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Edit("ProjectVersion", Fields, data.Id); AddSysLog(data.Id.ToString(), "ProjectVersion", "update"); db.SaveChanges(); return "success"; } #endregion #region 删除小程序版本信息 /// /// 删除小程序版本信息 /// /// public string Delete(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "ProjectVersion", "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("ProjectVersion", Fields, id); } db.SaveChanges(); return "success"; } #endregion #region 开启 /// /// 开启 /// /// public string Open(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "ProjectVersion", "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("ProjectVersion", Fields, id); } db.SaveChanges(); return "success"; } #endregion #region 关闭 /// /// 关闭 /// /// public string Close(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "ProjectVersion", "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("ProjectVersion", Fields, id); } db.SaveChanges(); return "success"; } #endregion #region 排序 /// /// 排序 /// /// public string Sort(int Id, int Sort) { new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).Sort("ProjectVersion", Sort, Id); AddSysLog(Id.ToString(), "ProjectVersion", "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.ProjectVersion.Add(new ProjectVersion() { CreateDate = DateTime.Now, UpdateDate = DateTime.Now, }); db.SaveChanges(); } AddSysLog("0", "ProjectVersion", "Import"); return "success"; } #endregion #region 导出Excel /// /// 导出Excel /// /// public JsonResult ExportExcel(ProjectVersion data, string ProjectIdSelect, string UserIdRealName, string UserIdMobile, string DeveloperIdNickName, string DeveloperIdRealName, string DeveloperIdMobile) { Dictionary Fields = new Dictionary(); Fields.Add("CreateDate", "3"); //时间 string condition = " and Status>-1"; //小程序项目 if (!string.IsNullOrEmpty(ProjectIdSelect)) { condition += " and ProjectId=" + ProjectIdSelect; } //所属用户真实姓名 if (!string.IsNullOrEmpty(UserIdRealName)) { condition += " and UserId in (select UserId from UsersForRealName where RealName='" + UserIdRealName + "')"; } //所属用户手机号 if (!string.IsNullOrEmpty(UserIdMobile)) { condition += " and UserId in (select UserId from UsersForMobile where Mobile='" + UserIdMobile + "')"; } //开发者昵称 if (!string.IsNullOrEmpty(DeveloperIdNickName)) { condition += " and DeveloperId in (select DeveloperId from DevelopersForNickName where NickName='" + DeveloperIdNickName + "')"; } //开发者真实姓名 if (!string.IsNullOrEmpty(DeveloperIdRealName)) { condition += " and DeveloperId in (select DeveloperId from DevelopersForRealName where RealName='" + DeveloperIdRealName + "')"; } //开发者手机号 if (!string.IsNullOrEmpty(DeveloperIdMobile)) { condition += " and DeveloperId in (select DeveloperId from DevelopersForMobile where Mobile='" + DeveloperIdMobile + "')"; } Dictionary obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.MainTables).IndexData("ProjectVersion", Fields, "Id desc", "0", 1, 20000, condition, "", false); List> diclist = obj["data"] as List>; foreach (Dictionary dic in diclist) { //小程序项目 // dic["ProjectId"] = RelationClass.GetProjectsInfo(int.Parse(dic["ProjectId"].ToString())); //所属用户 int UserId = int.Parse(function.CheckInt(dic["UserId"].ToString())); Users userid_Users = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users(); dic["UserIdRealName"] = userid_Users.RealName; dic["UserIdMobile"] = userid_Users.Mobile; dic.Remove("UserId"); //开发者 int DeveloperId = int.Parse(function.CheckInt(dic["DeveloperId"].ToString())); Developers developerid_Developers = db.Developers.FirstOrDefault(m => m.Id == DeveloperId) ?? new Developers(); dic["DeveloperIdNickName"] = developerid_Developers.NickName; dic["DeveloperIdRealName"] = developerid_Developers.RealName; dic["DeveloperIdMobile"] = developerid_Developers.Mobile; dic.Remove("DeveloperId"); } 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", "ProjectVersion", "ExportExcel"); return Json(result); } #endregion } }