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.
 
 
 
 
 
 

385 lines
13 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. if ((Exam_ExamPlanLessonData.ClassNum == null || Exam_ExamPlanLessonData.ClassNum <= 0) ||
  189. (Exam_ExamPlanLessonData.SeatCount == null || Exam_ExamPlanLessonData.SeatCount <= 0))
  190. {
  191. exam_ExamPlanLessonIBLL.UpdateClassNumAndStuCount(Exam_ExamPlanLessonData.EPLId);
  192. }
  193. var jsonData = new
  194. {
  195. Exam_ExamPlanLesson = Exam_ExamPlanLessonData,
  196. };
  197. return Success(jsonData);
  198. }
  199. /// <summary>
  200. /// 获取左侧树形数据
  201. /// </summary>
  202. /// <returns></returns>
  203. [HttpGet]
  204. [AjaxOnly]
  205. public ActionResult GetTree(string EPId)
  206. {
  207. var data = exam_ExamPlanLessonIBLL.GetTree(EPId);
  208. return Success(data);
  209. }
  210. [HttpGet]
  211. [AjaxOnly]
  212. public ActionResult ValidateRoom(string EPLId, string ClassroomNo)
  213. {
  214. var data = exam_ExamPlanRoomIBLL.ValidateRoom(EPLId, ClassroomNo);
  215. return Success(data);
  216. }
  217. #endregion
  218. #region 提交数据
  219. /// <summary>
  220. /// 初始化Exam_ExamPlanLesson,如果表中没有数据,将考试课程表数据添加进去
  221. /// </summary>
  222. /// <param name="EPId">排考记录主表Id</param>
  223. /// <returns></returns>
  224. [HttpPost]
  225. [AjaxOnly]
  226. public ActionResult InitExamPlanLesson(string EPId)
  227. {
  228. exam_ExamPlanLessonIBLL.InitExamPlanLesson(EPId);
  229. return Success("初始化成功!");
  230. }
  231. /// <summary>
  232. /// 删除实体数据
  233. /// </summary>
  234. /// <param name="keyValue">主键</param>
  235. /// <returns></returns>
  236. [HttpPost]
  237. [AjaxOnly]
  238. public ActionResult DeleteForm(string keyValue)
  239. {
  240. exam_ExamPlanLessonIBLL.DeleteEntity(keyValue);
  241. return Success("删除成功!");
  242. }
  243. [HttpPost]
  244. [AjaxOnly]
  245. public ActionResult DeleteClass(string keyValue)
  246. {
  247. exam_ExamPlanClassIBLL.DeleteEntity(keyValue);
  248. return Success("删除成功!");
  249. }
  250. [HttpPost]
  251. [AjaxOnly]
  252. public ActionResult DeleteRoom(string keyValue)
  253. {
  254. exam_ExamPlanRoomIBLL.DeleteEntity(keyValue);
  255. return Success("删除成功!");
  256. }
  257. /// <summary>
  258. /// 审核
  259. /// </summary>
  260. /// <param name="keyValue">主键</param>
  261. /// <returns></returns>
  262. [HttpPost]
  263. [AjaxOnly]
  264. public ActionResult Check(string keyValue, int ELCheckMark)
  265. {
  266. if (ELCheckMark == 1)
  267. {
  268. var entity = exam_ExamPlanLessonIBLL.GetExam_ExamPlanLessonEntity(keyValue);
  269. if (entity.ExamDate == null || entity.ExamTime == null)
  270. {
  271. return Fail("请先设置考试时间!");
  272. }
  273. if ((entity.RealClassNum == null || entity.RealClassNum == 0) ||
  274. (entity.SeatCount == null || entity.SeatCount == 0))
  275. {
  276. return Fail("请先安排班级和考场!");
  277. }
  278. if (entity.SeatCount < entity.RealStuCount)
  279. {
  280. return Fail("考场座位数不足!");
  281. }
  282. }
  283. exam_ExamPlanLessonIBLL.Check(keyValue, ELCheckMark);
  284. return Success("操作成功!");
  285. }
  286. /// <summary>
  287. /// 保存实体数据(新增、修改)
  288. /// 设置考试时间
  289. /// </summary>
  290. /// <param name="keyValue">主键</param>
  291. /// <param name="strEntity">实体</param>
  292. /// <returns></returns>
  293. [HttpPost]
  294. [ValidateAntiForgeryToken]
  295. [AjaxOnly]
  296. public ActionResult SaveForm(string keyValue, string strEntity)
  297. {
  298. Exam_ExamPlanLessonEntity entity = strEntity.ToObject<Exam_ExamPlanLessonEntity>();
  299. DateTime time;
  300. bool flag = DateTime.TryParse(entity.ExamTimeStart, out time);
  301. if (!flag)
  302. {
  303. return Fail("考试开始时间格式不正确!");
  304. }
  305. if (!DateTime.TryParse(entity.ExamTimeEnd, out time))
  306. {
  307. return Fail("考试结束时间格式不正确!");
  308. }
  309. if (!string.IsNullOrEmpty(entity.ExamTimeStart) && !string.IsNullOrEmpty(entity.ExamTimeEnd))
  310. {
  311. entity.ExamTime = entity.ExamTimeStart.Trim() + "-" + entity.ExamTimeEnd;
  312. }
  313. entity.EPLId = keyValue;
  314. //判断考试时间是否冲突
  315. //var res = exam_ExamPlanLessonIBLL.IsExamTimeClash(entity);
  316. //if (res.flag && !string.IsNullOrEmpty(res.lessonname))
  317. //{
  318. // return Fail("考试时间与课程(" + res.lessonname + ")冲突!");
  319. //}
  320. //保存
  321. exam_ExamPlanLessonIBLL.SaveEntity(keyValue, entity);
  322. return Success("保存成功!");
  323. }
  324. [HttpPost]
  325. [ValidateAntiForgeryToken]
  326. [AjaxOnly]
  327. public ActionResult SaveClass(string EPLId, string strEntity)
  328. {
  329. var list = strEntity.ToObject<List<Exam_ExamPlanClassEntity>>();
  330. //判断排考班级的考试时间是否冲突
  331. var res = exam_ExamPlanClassIBLL.IsExamConflict(list);
  332. if (res.flag && !string.IsNullOrEmpty(res.msg))
  333. {
  334. return Fail(res.msg);
  335. }
  336. exam_ExamPlanClassIBLL.SaveList(list);
  337. return Success("保存成功!");
  338. }
  339. [HttpPost]
  340. [ValidateAntiForgeryToken]
  341. [AjaxOnly]
  342. public ActionResult SaveRoomAndTeacher(string keyValue, string strEntity, string Exam_ExamPlanTeacherList)
  343. {
  344. var entity = strEntity.ToObject<Exam_ExamPlanRoomEntity>();
  345. var teacherList = Exam_ExamPlanTeacherList.ToObject<List<Exam_InvigilateTeacherEntity>>();
  346. entity.EmpNo = string.Join(",", teacherList.Select(x => x.EmpNo).ToList());
  347. entity.EmpName = string.Join(",", teacherList.Select(x => x.EmpName).ToList());
  348. exam_ExamPlanRoomIBLL.SaveEntity(keyValue, entity);
  349. return Success("保存成功!");
  350. }
  351. #endregion
  352. }
  353. }