You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

379 lines
12 KiB

  1. using Learun.Util;
  2. using System.Data;
  3. using Learun.Application.TwoDevelopment.EducationalAdministration;
  4. using System.Web.Mvc;
  5. using System.Collections.Generic;
  6. using System;
  7. using System.Linq;
  8. namespace Learun.Application.Web.Areas.EducationalAdministration.Controllers
  9. {
  10. /// <summary>
  11. /// 版 本 Learun-ADMS V7.0.6 力软敏捷开发框架
  12. /// Copyright (c) 2013-2020 力软信息技术(苏州)有限公司
  13. /// 创 建:超级管理员
  14. /// 日 期:2022-04-15 15:03
  15. /// 描 述:排考安排课程
  16. /// </summary>
  17. public class Exam_ExamPlanLessonController : MvcControllerBase
  18. {
  19. private Exam_ExamPlanLessonIBLL exam_ExamPlanLessonIBLL = new Exam_ExamPlanLessonBLL();
  20. private Exam_ExamPlanClassIBLL exam_ExamPlanClassIBLL = new Exam_ExamPlanClassBLL();
  21. private Exam_ExamStudentIBLL exam_ExamStudentIBLL = new Exam_ExamStudentBLL();
  22. private Exam_ExamPlanRoomIBLL exam_ExamPlanRoomIBLL = new Exam_ExamPlanRoomBLL();
  23. private StuInfoBasicIBLL StuInfoBasicIBLL = new StuInfoBasicBLL();
  24. #region 视图功能
  25. /// <summary>
  26. /// 主页面
  27. /// </summary>
  28. /// <param name="EPId">排考记录主表Id</param>
  29. /// <returns></returns>
  30. [HttpGet]
  31. public ActionResult Index(string EPId)
  32. {
  33. exam_ExamPlanLessonIBLL.InitExamPlanLesson(EPId);
  34. return View();
  35. }
  36. /// <summary>
  37. /// 表单页
  38. /// <summary>
  39. /// <returns></returns>
  40. [HttpGet]
  41. public ActionResult Form()
  42. {
  43. return View();
  44. }
  45. [HttpGet]
  46. public ActionResult FormClass()
  47. {
  48. return View();
  49. }
  50. [HttpGet]
  51. public ActionResult FormRoom()
  52. {
  53. return View();
  54. }
  55. [HttpGet]
  56. public ActionResult FormTeacher()
  57. {
  58. return View();
  59. }
  60. [HttpGet]
  61. public ActionResult FormRoomTeacher()
  62. {
  63. return View();
  64. }
  65. #endregion
  66. #region 获取数据
  67. /// <summary>
  68. /// 获取班级分页列表
  69. /// </summary>
  70. /// <param name="pagination"></param>
  71. /// <param name="queryJson"></param>
  72. /// <returns></returns>
  73. [HttpGet]
  74. [AjaxOnly]
  75. public ActionResult GetClassInfoPageList(string pagination, string queryJson)
  76. {
  77. Pagination paginationobj = pagination.ToObject<Pagination>();
  78. var data = exam_ExamStudentIBLL.GetPageListForExam(paginationobj, queryJson);
  79. //var stuList = StuInfoBasicIBLL.GetAllList();
  80. //foreach (var item in data)
  81. //{
  82. // item.StuNum = stuList.Count(x => x.ClassNo == item.ClassNo);
  83. //}
  84. var jsonData = new
  85. {
  86. rows = data,
  87. total = paginationobj.total,
  88. page = paginationobj.page,
  89. records = paginationobj.records
  90. };
  91. return Success(jsonData);
  92. }
  93. /// <summary>
  94. /// 获取页面显示列表数据
  95. /// </summary>
  96. /// <param name="pagination">分页参数</param>
  97. /// <param name="queryJson">查询参数</param>
  98. /// <returns></returns>
  99. [HttpGet]
  100. [AjaxOnly]
  101. public ActionResult GetListForClass(string queryJson)
  102. {
  103. var data = exam_ExamPlanClassIBLL.GetList(queryJson);
  104. return Success(data);
  105. }
  106. /// <summary>
  107. /// 获取页面显示列表数据
  108. /// </summary>
  109. /// <param name="pagination">分页参数</param>
  110. /// <param name="queryJson">查询参数</param>
  111. /// <returns></returns>
  112. [HttpGet]
  113. [AjaxOnly]
  114. public ActionResult GetListForRoom(string pagination, string queryJson)
  115. {
  116. var data = exam_ExamPlanRoomIBLL.GetList(queryJson);
  117. return Success(data);
  118. }
  119. /// <summary>
  120. /// 获取页面显示列表数据
  121. /// </summary>
  122. /// <param name="pagination">分页参数</param>
  123. /// <param name="queryJson">查询参数</param>
  124. /// <returns></returns>
  125. [HttpGet]
  126. [AjaxOnly]
  127. public ActionResult GetPageList(string pagination, string queryJson)
  128. {
  129. Pagination paginationobj = pagination.ToObject<Pagination>();
  130. var data = exam_ExamPlanLessonIBLL.GetPageList(paginationobj, queryJson);
  131. var jsonData = new
  132. {
  133. rows = data,
  134. total = paginationobj.total,
  135. page = paginationobj.page,
  136. records = paginationobj.records
  137. };
  138. return Success(jsonData);
  139. }
  140. /// <summary>
  141. /// 排考计划
  142. /// </summary>
  143. /// <param name="pagination"></param>
  144. /// <param name="queryJson"></param>
  145. /// <returns></returns>
  146. [HttpGet]
  147. [AjaxOnly]
  148. public ActionResult GetPageListForLesson(string pagination, string queryJson)
  149. {
  150. Pagination paginationobj = pagination.ToObject<Pagination>();
  151. var data = exam_ExamPlanLessonIBLL.GetPageListForLesson(paginationobj, queryJson);
  152. var jsonData = new
  153. {
  154. rows = data,
  155. total = paginationobj.total,
  156. page = paginationobj.page,
  157. records = paginationobj.records
  158. };
  159. return Success(jsonData);
  160. }
  161. [HttpGet]
  162. [AjaxOnly]
  163. public ActionResult GetFormRoom(string keyValue)
  164. {
  165. var data = exam_ExamPlanRoomIBLL.GetEntity(keyValue);
  166. var jsonData = new
  167. {
  168. Exam_ExamPlanRoom = data,
  169. };
  170. return Success(jsonData);
  171. }
  172. /// <summary>
  173. /// 获取表单数据
  174. /// </summary>
  175. /// <param name="keyValue">主键</param>
  176. /// <returns></returns>
  177. [HttpGet]
  178. [AjaxOnly]
  179. public ActionResult GetFormData(string keyValue)
  180. {
  181. var Exam_ExamPlanLessonData = exam_ExamPlanLessonIBLL.GetExam_ExamPlanLessonEntity(keyValue);
  182. if (!string.IsNullOrEmpty(Exam_ExamPlanLessonData.ExamTime))
  183. {
  184. var etime = Exam_ExamPlanLessonData.ExamTime.Split('-');
  185. Exam_ExamPlanLessonData.ExamTimeStart = etime[0];
  186. Exam_ExamPlanLessonData.ExamTimeEnd = etime[1];
  187. }
  188. var jsonData = new
  189. {
  190. Exam_ExamPlanLesson = Exam_ExamPlanLessonData,
  191. };
  192. return Success(jsonData);
  193. }
  194. /// <summary>
  195. /// 获取左侧树形数据
  196. /// </summary>
  197. /// <returns></returns>
  198. [HttpGet]
  199. [AjaxOnly]
  200. public ActionResult GetTree(string EPId)
  201. {
  202. var data = exam_ExamPlanLessonIBLL.GetTree(EPId);
  203. return Success(data);
  204. }
  205. [HttpGet]
  206. [AjaxOnly]
  207. public ActionResult ValidateRoom(string EPLId, string ClassroomNo)
  208. {
  209. var data = exam_ExamPlanRoomIBLL.ValidateRoom(EPLId, ClassroomNo);
  210. return Success(data);
  211. }
  212. #endregion
  213. #region 提交数据
  214. /// <summary>
  215. /// 初始化Exam_ExamPlanLesson,如果表中没有数据,将考试课程表数据添加进去
  216. /// </summary>
  217. /// <param name="EPId">排考记录主表Id</param>
  218. /// <returns></returns>
  219. [HttpPost]
  220. [AjaxOnly]
  221. public ActionResult InitExamPlanLesson(string EPId)
  222. {
  223. exam_ExamPlanLessonIBLL.InitExamPlanLesson(EPId);
  224. return Success("初始化成功!");
  225. }
  226. /// <summary>
  227. /// 删除实体数据
  228. /// </summary>
  229. /// <param name="keyValue">主键</param>
  230. /// <returns></returns>
  231. [HttpPost]
  232. [AjaxOnly]
  233. public ActionResult DeleteForm(string keyValue)
  234. {
  235. exam_ExamPlanLessonIBLL.DeleteEntity(keyValue);
  236. return Success("删除成功!");
  237. }
  238. [HttpPost]
  239. [AjaxOnly]
  240. public ActionResult DeleteClass(string keyValue)
  241. {
  242. exam_ExamPlanClassIBLL.DeleteEntity(keyValue);
  243. return Success("删除成功!");
  244. }
  245. [HttpPost]
  246. [AjaxOnly]
  247. public ActionResult DeleteRoom(string keyValue)
  248. {
  249. exam_ExamPlanRoomIBLL.DeleteEntity(keyValue);
  250. return Success("删除成功!");
  251. }
  252. /// <summary>
  253. /// 审核
  254. /// </summary>
  255. /// <param name="keyValue">主键</param>
  256. /// <returns></returns>
  257. [HttpPost]
  258. [AjaxOnly]
  259. public ActionResult Check(string keyValue, int ELCheckMark)
  260. {
  261. if (ELCheckMark == 1)
  262. {
  263. var entity = exam_ExamPlanLessonIBLL.GetExam_ExamPlanLessonEntity(keyValue);
  264. if (entity.ExamDate == null || entity.ExamTime == null)
  265. {
  266. return Fail("请先设置考试时间!");
  267. }
  268. if ((entity.RealClassNum == null || entity.RealClassNum == 0) ||
  269. (entity.SeatCount == null || entity.SeatCount == 0))
  270. {
  271. return Fail("请先安排班级和考场!");
  272. }
  273. if (entity.SeatCount < entity.RealStuCount)
  274. {
  275. return Fail("考场座位数不足!");
  276. }
  277. }
  278. exam_ExamPlanLessonIBLL.Check(keyValue, ELCheckMark);
  279. return Success("操作成功!");
  280. }
  281. /// <summary>
  282. /// 保存实体数据(新增、修改)
  283. /// 设置考试时间
  284. /// </summary>
  285. /// <param name="keyValue">主键</param>
  286. /// <param name="strEntity">实体</param>
  287. /// <returns></returns>
  288. [HttpPost]
  289. [ValidateAntiForgeryToken]
  290. [AjaxOnly]
  291. public ActionResult SaveForm(string keyValue, string strEntity)
  292. {
  293. Exam_ExamPlanLessonEntity entity = strEntity.ToObject<Exam_ExamPlanLessonEntity>();
  294. DateTime time;
  295. bool flag = DateTime.TryParse(entity.ExamTimeStart, out time);
  296. if (!flag)
  297. {
  298. return Fail("考试开始时间格式不正确!");
  299. }
  300. if (!DateTime.TryParse(entity.ExamTimeEnd, out time))
  301. {
  302. return Fail("考试结束时间格式不正确!");
  303. }
  304. if (!string.IsNullOrEmpty(entity.ExamTimeStart) && !string.IsNullOrEmpty(entity.ExamTimeEnd))
  305. {
  306. entity.ExamTime = entity.ExamTimeStart.Trim() + "-" + entity.ExamTimeEnd;
  307. }
  308. entity.EPLId = keyValue;
  309. //判断考试时间是否冲突
  310. //var res = exam_ExamPlanLessonIBLL.IsExamTimeClash(entity);
  311. //if (res.flag && !string.IsNullOrEmpty(res.lessonname))
  312. //{
  313. // return Fail("考试时间与课程(" + res.lessonname + ")冲突!");
  314. //}
  315. //保存
  316. exam_ExamPlanLessonIBLL.SaveEntity(keyValue, entity);
  317. return Success("保存成功!");
  318. }
  319. [HttpPost]
  320. [ValidateAntiForgeryToken]
  321. [AjaxOnly]
  322. public ActionResult SaveClass(string EPLId, string strEntity)
  323. {
  324. var list = strEntity.ToObject<List<Exam_ExamPlanClassEntity>>();
  325. //判断排考班级的考试时间是否冲突
  326. var res = exam_ExamPlanClassIBLL.IsExamConflict(list);
  327. if (res.flag && !string.IsNullOrEmpty(res.msg))
  328. {
  329. return Fail(res.msg);
  330. }
  331. exam_ExamPlanClassIBLL.SaveList(list);
  332. return Success("保存成功!");
  333. }
  334. [HttpPost]
  335. [ValidateAntiForgeryToken]
  336. [AjaxOnly]
  337. public ActionResult SaveRoomAndTeacher(string keyValue, string strEntity, string Exam_ExamPlanTeacherList)
  338. {
  339. var entity = strEntity.ToObject<Exam_ExamPlanRoomEntity>();
  340. var teacherList = Exam_ExamPlanTeacherList.ToObject<List<Exam_InvigilateTeacherEntity>>();
  341. entity.EmpNo = string.Join(",", teacherList.Select(x => x.EmpNo).ToList());
  342. entity.EmpName = string.Join(",", teacherList.Select(x => x.EmpName).ToList());
  343. exam_ExamPlanRoomIBLL.SaveEntity(keyValue, entity);
  344. return Success("保存成功!");
  345. }
  346. #endregion
  347. }
  348. }