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.

преди 4 години
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Configuration;
  4. using System.Data;
  5. using System.Data.SqlClient;
  6. using System.Linq;
  7. using System.Threading.Tasks;
  8. using System.Web;
  9. using Learun.Application.Organization;
  10. using Learun.Application.TwoDevelopment.EducationalAdministration;
  11. using Learun.Util;
  12. using Nancy;
  13. namespace Learun.Application.WebApi.Modules
  14. {
  15. public class TimeTable : BaseApi
  16. {
  17. public TimeTable()
  18. : base("/learun/adms/timetable")
  19. {
  20. Get["/list"] = GetList;
  21. Get["/StuList"] = GetStuInfo;
  22. Get["/StuLessonInfo"] = GetStuLessonInfo;
  23. }
  24. private ArrangeLessonTermIBLL arrangeLessonTermIBLL = new ArrangeLessonTermBLL();
  25. private ArrangeLessonTermOfElectiveIBLL arrangeLessonTermOfElectiveIBLL = new ArrangeLessonTermOfElectiveBLL();
  26. private StuAttendanceLeaveIBLL stuAttendanceLeaveIBLL = new StuAttendanceLeaveBLL();
  27. private StuAttendanceIBLL stuAttendanceIBLL = new StuAttendanceBLL();
  28. /// <summary>
  29. /// 课程表【教师功能、学生功能】
  30. /// </summary>
  31. /// <param name="_"></param>
  32. /// <returns></returns>
  33. public Response GetList(dynamic _)
  34. {
  35. var param = this.GetReqData<TimeParameter>();
  36. var timeTableList = new List<TwoDevelopment.EducationalAdministration.TimeTable>();
  37. //课程表
  38. var data = arrangeLessonTermIBLL.GetTimeTable(userInfo.account, userInfo.Description, param.StartDate, param.EndDate);
  39. timeTableList.AddRange(data);
  40. //选修课课程表
  41. var dataOfElective = arrangeLessonTermOfElectiveIBLL.GetTimeTable(userInfo.account, userInfo.Description, param.StartDate, param.EndDate);
  42. timeTableList.AddRange(dataOfElective);
  43. var leaveList = stuAttendanceLeaveIBLL.GetList();
  44. foreach (var item in timeTableList)
  45. {
  46. item.LeaveType = leaveList.Any(c => c.LessonNo == item.LessonNo && c.StuNo == userInfo.account && c.LessonDate == item.LessonDate && c.LessonTime == item.LessonTime) ? "1" : "0";
  47. item.IsCheck = leaveList.FirstOrDefault(c => c.LessonNo == item.LessonNo && c.StuNo == userInfo.account && c.LessonDate == item.LessonDate && c.LessonTime == item.LessonTime)?.IsCheck;
  48. }
  49. return Success(timeTableList);
  50. }
  51. /// <summary>
  52. /// 获取本堂课的学生出勤信息
  53. /// </summary>
  54. /// <param name="_"></param>
  55. /// <returns></returns>
  56. public Response GetStuInfo(dynamic _)
  57. {
  58. var param = this.GetReqData<TwoDevelopment.EducationalAdministration.TimeTable>();
  59. var result = stuAttendanceIBLL.GetStuInfo(param.AcademicYear, param.Semester, param.LessonNo, param.EmpNo, param.ClassRoomNo, param.LessonTime, param.LessonDate, param.TeachClassNo);
  60. var date = Convert.ToDateTime(param.LessonDate).ToString("yyyy-MM-dd");
  61. var time = NumberToChinese(param.LessonTime.Substring(1, 1));
  62. if (result.Count > 0)
  63. {
  64. var shouldArrive = result.Count;
  65. var turnTo = result.Count(a => a.AttendOrNo == "是");
  66. var classRoomName = param.ClassroomName;
  67. var className = result.FirstOrDefault().ClassName;
  68. var lessonName = result.FirstOrDefault().LessonName;
  69. return Success(new { result, date, time, shouldArrive, turnTo, classRoomName, className, lessonName });
  70. }
  71. else
  72. {
  73. return Success(new { result, date, time });
  74. }
  75. }
  76. public Response GetStuLessonInfo(dynamic _)
  77. {
  78. var lessonInfos = stuAttendanceIBLL.GetStuLessonInfo(userInfo.account);
  79. var empNos = lessonInfos.Select(a => a.EmpNo).ToList();
  80. var lessonTerms = arrangeLessonTermIBLL.GetListByEmpNo(empNos);
  81. var list = lessonInfos.Select(a => new
  82. {
  83. a.LessonName,
  84. LessonDate = Convert.ToDateTime(a.LessonDate).ToString("yyyy-MM-dd"),
  85. Teacher = lessonTerms.FirstOrDefault(b => b.EmpNo == a.EmpNo).EmpName,
  86. a.LessonTime,
  87. a.EmpNo,
  88. a.ClassRoomName,
  89. a.Sort
  90. }).ToList();
  91. var weeks = list.GroupBy(a => a.LessonDate).ToList();
  92. List<object> results = new List<object>();
  93. foreach (var item in weeks)
  94. {
  95. var weekList = list.Where(a => a.LessonDate == item.Key).ToList();
  96. var week = weekList[0].LessonTime.Substring(0, 1);
  97. var result = new { week, weekList };
  98. results.Add(result);
  99. }
  100. return Success(results);
  101. }
  102. /// <summary>
  103. /// 数字转中文
  104. /// </summary>
  105. /// <param name="number">eg: 22</param>
  106. /// <returns></returns>
  107. public string NumberToChinese(string number)
  108. {
  109. string res = string.Empty;
  110. switch (number)
  111. {
  112. case "1":
  113. res = "一";
  114. break;
  115. case "2":
  116. res = "二";
  117. break;
  118. case "3":
  119. res = "三";
  120. break;
  121. case "4":
  122. res = "四";
  123. break;
  124. case "5":
  125. res = "五";
  126. break;
  127. case "6":
  128. res = "六";
  129. break;
  130. case "7":
  131. res = "七";
  132. break;
  133. case "8":
  134. res = "八";
  135. break;
  136. case "9":
  137. res = "九";
  138. break;
  139. default:
  140. res = "零";
  141. break;
  142. }
  143. return res;
  144. }
  145. }
  146. public class TimeParameter
  147. {
  148. public string StartDate { get; set; }
  149. public string EndDate { get; set; }
  150. }
  151. }