using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using EMIS.CommonLogic.ExaminationApply;
using EMIS.ViewModel;
using EMIS.Web.Controls;
using Bowin.Web.Controls.Mvc;
using Bowin.Common.Utility;
using Bowin.Common.Data;
using EMIS.ViewModel.ExaminationApply;
using Bowin.Common.Exceptions;
namespace EMIS.Web.Controllers.ExaminationApply
{
[Authorization]
public class ExaminationTypeController : Controller
{
public IExaminationTypeServices ExaminationTypeServices { get; set; }
///
/// 考试类型页面
///
///
public ActionResult List()
{
return View();
}
public ActionResult Edit(Guid? ExaminationTypeID)
{
ExaminationTypeView examinationTypeView = new ExaminationTypeView();
if (ExaminationTypeID != null && ExaminationTypeID != Guid.Empty)
{
examinationTypeView = ExaminationTypeServices.GetExaminationTypeViewInfo(ExaminationTypeID);
}
return View(examinationTypeView);
}
///
/// 列表查询
///
///
///
[HttpPost]
public ActionResult List(QueryParamsModel pararms)
{
ConfiguretView configuretView = ConfiguretExtensions.GetConfiguretermsView(pararms);
if (configuretView.Attribute == Bowin.Web.Controls.Mvc.DropdownList.SELECT_ALL.ToString()) configuretView.Attribute = "";
return base.Json(ExaminationTypeServices.GetExaminationTypeViewList(configuretView, (int)pararms.page, (int)pararms.rows));
}
[HttpPost]
public ActionResult Excel()
{
NpoiExcelHelper neh = new NpoiExcelHelper();
ConfiguretView configuretView = ConfiguretExtensions.GetConfiguretermsView(null);
if (configuretView.Attribute == Bowin.Web.Controls.Mvc.DropdownList.SELECT_ALL.ToString()) configuretView.Attribute = "";
var query = ExaminationTypeServices.GetExaminationTypeViewList(configuretView);
var SelectedID = Request.Form["SelectedID"];
List selectIDlist = new List();
if (SelectedID != "" && SelectedID != null)
{
selectIDlist = SelectedID.SplitIDString();
query = query.Where(x => selectIDlist.Contains(x.ExaminationTypeID)).ToList();
}
var dt = query.Select(x => new
{
x.Name,
x.IsTimesLimitDesc
}).ToTable();
string[] liststring = { "考试类型", "是否要求次数限定" };
neh.Export(dt, liststring, "考试类型信息");
return RedirectToAction("MsgShow", "Common", new
{
msg = "导出成功!",
url = Url.Content("~/ExaminationType/List").AddMenuParameter()
});
}
///
/// 删除
///
///
///
[HttpPost]
public ActionResult Delete(string examinationTypeIDs)
{
try
{
var examinationTypeIDList = examinationTypeIDs.Split(',').Select(x => (Guid?)new Guid(x)).ToList();
ExaminationTypeServices.Delete(examinationTypeIDList);
return base.Json("删除成功");
}
catch (Exception ex)
{
string mge = ex.Message;
System.Data.SqlClient.SqlException num = ExceptionHelper.GetSqlException(ex);
if (num != null)
{
if (num.Number == 547)
mge = "请先删除所有关联的数据,如:考试科目、考场安排等";
}
return base.Json("删除失败,原因:" + mge + "!");
}
}
///
/// 修改
///
///
[HttpPost]
public ActionResult Edit(ExaminationTypeView examinationTypeView)
{
try
{
//同一类型需作唯一性判断
var model = ExaminationTypeServices.GetView(x => x.Name == examinationTypeView.Name && x.ExaminationTypeID != examinationTypeView.ExaminationTypeID);
if (model != null)
{
return Json(new ReturnMessage()
{
IsSuccess = false,
Message = "类型不允许相同!"
});
}
var user = HttpContext.User as EMIS.Utility.FormValidate.CustomPrincipal;
ExaminationTypeServices.Save(examinationTypeView);
return Json(new ReturnMessage()
{
IsSuccess = true,
Message = "保存成功!"
});
}
catch (Exception ex)
{
return Json(new ReturnMessage()
{
IsSuccess = false,
Message = "保存失败:" + ex.Message
});
}
}
[HttpPost]
public ActionResult DropdownList(DropdownListBindType? bindType)
{
List list = ExaminationTypeServices.GetExaminationTypeViewList(new ConfiguretView())
.Select(x => new DropdownListItem { Text = x.Name, Value = x.ExaminationTypeID.ToString() }).ToList();
DropdownListBindType dbt = bindType == null ? DropdownListBindType.SelectAll : bindType.Value;
Bowin.Web.Controls.Mvc.DropdownList.FormatDropdownItemList(dbt, list);
return base.Json(list);
}
}
}