Du kannst nicht mehr als 25 Themen auswählen Themen müssen entweder mit einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.
 
 
 
 
 
 

258 Zeilen
9.8 KiB

  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 : BaseNoLoginApi
  16. {
  17. public TimeTable()
  18. : base("/learun/adms/timetable")
  19. {
  20. Get["/list"] = GetList;
  21. Get["/StuList"] = GetStuInfo;
  22. Get["/StuLessonInfo"] = GetStuLessonInfo;
  23. Get["/timeTableData"] = GetTimeTableData;
  24. }
  25. private ArrangeLessonTermIBLL arrangeLessonTermIBLL = new ArrangeLessonTermBLL();
  26. private ArrangeLessonTermOfElectiveIBLL arrangeLessonTermOfElectiveIBLL = new ArrangeLessonTermOfElectiveBLL();
  27. private StuAttendanceLeaveIBLL stuAttendanceLeaveIBLL = new StuAttendanceLeaveBLL();
  28. private StuAttendanceIBLL stuAttendanceIBLL = new StuAttendanceBLL();
  29. /// <summary>
  30. /// 课程表【教师功能、学生功能】
  31. /// </summary>
  32. /// <param name="_"></param>
  33. /// <returns></returns>
  34. public Response GetList(dynamic _)
  35. {
  36. var param = this.GetReqData<TimeParameter>();
  37. var timeTableList = new List<TwoDevelopment.EducationalAdministration.TimeTable>();
  38. //课程表
  39. var data = arrangeLessonTermIBLL.GetTimeTable(userInfo.account, userInfo.Description, param.StartDate, param.EndDate);
  40. timeTableList.AddRange(data);
  41. //选修课课程表
  42. var dataOfElective = arrangeLessonTermOfElectiveIBLL.GetTimeTable(userInfo.account, userInfo.Description, param.StartDate, param.EndDate);
  43. timeTableList.AddRange(dataOfElective);
  44. var leaveList = stuAttendanceLeaveIBLL.GetList();
  45. foreach (var item in timeTableList)
  46. {
  47. item.LeaveType = leaveList.Any(c => c.LessonNo == item.LessonNo && c.StuNo == userInfo.account && c.LessonDate == item.LessonDate && c.LessonTime == item.LessonTime) ? "1" : "0";
  48. item.IsCheck = leaveList.FirstOrDefault(c => c.LessonNo == item.LessonNo && c.StuNo == userInfo.account && c.LessonDate == item.LessonDate && c.LessonTime == item.LessonTime)?.IsCheck;
  49. }
  50. return Success(timeTableList);
  51. }
  52. /// <summary>
  53. /// 获取本堂课的学生出勤信息
  54. /// </summary>
  55. /// <param name="_"></param>
  56. /// <returns></returns>
  57. public Response GetStuInfo(dynamic _)
  58. {
  59. var param = this.GetReqData<TwoDevelopment.EducationalAdministration.TimeTable>();
  60. var result = stuAttendanceIBLL.GetStuInfo(param.AcademicYear, param.Semester, param.LessonNo, param.EmpNo, param.ClassRoomNo, param.LessonTime, param.LessonDate, param.TeachClassNo);
  61. var date = Convert.ToDateTime(param.LessonDate).ToString("yyyy-MM-dd");
  62. var time = NumberToChinese(param.LessonTime.Substring(1, 1));
  63. if (result.Count > 0)
  64. {
  65. var shouldArrive = result.Count;
  66. var turnTo = result.Count(a => a.AttendOrNo == "是");
  67. var classRoomName = param.ClassroomName;
  68. var className = result.FirstOrDefault().ClassName;
  69. var lessonName = result.FirstOrDefault().LessonName;
  70. return Success(new { result, date, time, shouldArrive, turnTo, classRoomName, className, lessonName });
  71. }
  72. else
  73. {
  74. return Success(new { result, date, time });
  75. }
  76. }
  77. public Response GetStuLessonInfo(dynamic _)
  78. {
  79. var lessonInfos = stuAttendanceIBLL.GetStuLessonInfo(userInfo.account);
  80. var empNos = lessonInfos.Select(a => a.EmpNo).ToList();
  81. var lessonTerms = arrangeLessonTermIBLL.GetListByEmpNo(empNos);
  82. var list = lessonInfos.Select(a => new
  83. {
  84. a.LessonName,
  85. LessonDate = Convert.ToDateTime(a.LessonDate).ToString("yyyy-MM-dd"),
  86. Teacher = lessonTerms.FirstOrDefault(b => b.EmpNo == a.EmpNo).EmpName,
  87. a.LessonTime,
  88. a.EmpNo,
  89. a.ClassRoomName,
  90. a.Sort
  91. }).ToList();
  92. var weeks = list.GroupBy(a => a.LessonDate).ToList();
  93. List<object> results = new List<object>();
  94. foreach (var item in weeks)
  95. {
  96. var weekList = list.Where(a => a.LessonDate == item.Key).ToList();
  97. var week = weekList[0].LessonTime.Substring(0, 1);
  98. var result = new { week, weekList };
  99. results.Add(result);
  100. }
  101. return Success(results);
  102. }
  103. /// <summary>
  104. /// 全院课程表【按班级分组】
  105. /// </summary>
  106. /// <param name="_"></param>
  107. /// <returns></returns>
  108. private Response GetTimeTableData(dynamic _)
  109. {
  110. var param = this.GetReq<TimeParameter>();
  111. TimeTableData result = new TimeTableData();
  112. //开始时间
  113. var startdate = string.IsNullOrEmpty(param.StartDate) ? DateTime.Today : Convert.ToDateTime(param.StartDate);
  114. var startDate = Common.CalculateFirstDateOfWeek(startdate).ToString("yyyy-MM-dd");
  115. var endDate = Common.CalculateLastDateOfWeek(startdate).ToString("yyyy-MM-dd");
  116. result.StartDate = startDate;
  117. result.EndDate = endDate;
  118. var semesterAndYear = Common.GetSemesterAndYear(startDate);
  119. result.AcademicYearNo = semesterAndYear.AcademicYearLong;
  120. result.Semester = semesterAndYear.Semester;
  121. //课程表数据
  122. var timeTableList = new List<Learun.Application.TwoDevelopment.EducationalAdministration.TimeTable>();
  123. //必修课课程表
  124. var data = arrangeLessonTermIBLL.GetTimeTableInEducation(startDate, endDate, param.ClassNo, param.EmpNo, "");
  125. timeTableList.AddRange(data);
  126. //选修课课程表
  127. var dataOfElective = arrangeLessonTermOfElectiveIBLL.GetTimeTableInEducation(startDate, endDate, param.ClassNo, param.EmpNo, "");
  128. timeTableList.AddRange(dataOfElective);
  129. var dataTemp = timeTableList.GroupBy(x => new { x.TeachClassNo, x.ClassName, x.LessonSortNo }).Select(x => new ClassDataList()
  130. {
  131. ClassNo = x.Key.TeachClassNo,
  132. ClassName = x.Key.ClassName,
  133. LessonSortNo = x.Key.LessonSortNo,
  134. TimeTableList = x.Select(y => new TwoDevelopment.EducationalAdministration.TimeTable()
  135. {
  136. AcademicYear = y.AcademicYear,
  137. Semester = y.Semester,
  138. DeptNo = y.DeptNo,
  139. MajorNo = y.MajorNo,
  140. F_SchoolId = y.F_SchoolId,
  141. LessonNo = y.LessonNo,
  142. LessonName = y.LessonName,
  143. LessonDate = y.LessonDate,
  144. LessonTime = y.LessonTime,
  145. EmpNo = y.EmpNo,
  146. EmpName = y.EmpName,
  147. TeachClassNo = y.TeachClassNo,
  148. ClassName = y.ClassName,
  149. ClassRoomNo = y.ClassRoomNo,
  150. ClassroomName = y.ClassroomName,
  151. LessonSortNo = y.LessonSortNo
  152. }).OrderBy(a => a.LessonTime.Substring(0, 1)).ThenBy(a => a.LessonTime.Substring(1)).ToList()
  153. }).OrderBy(x => x.LessonSortNo).ThenBy(x => x.ClassNo).ToList();
  154. result.ClassDataList = dataTemp;
  155. return Success(result);
  156. }
  157. /// <summary>
  158. /// 数字转中文
  159. /// </summary>
  160. /// <param name="number">eg: 22</param>
  161. /// <returns></returns>
  162. public string NumberToChinese(string number)
  163. {
  164. string res = string.Empty;
  165. switch (number)
  166. {
  167. case "1":
  168. res = "一";
  169. break;
  170. case "2":
  171. res = "二";
  172. break;
  173. case "3":
  174. res = "三";
  175. break;
  176. case "4":
  177. res = "四";
  178. break;
  179. case "5":
  180. res = "五";
  181. break;
  182. case "6":
  183. res = "六";
  184. break;
  185. case "7":
  186. res = "七";
  187. break;
  188. case "8":
  189. res = "八";
  190. break;
  191. case "9":
  192. res = "九";
  193. break;
  194. default:
  195. res = "零";
  196. break;
  197. }
  198. return res;
  199. }
  200. }
  201. public class TimeParameter
  202. {
  203. public string StartDate { get; set; }
  204. public string EndDate { get; set; }
  205. /// <summary>
  206. /// 班级编号
  207. /// </summary>
  208. public string ClassNo { get; set; }
  209. /// <summary>
  210. /// 教师编号
  211. /// </summary>
  212. public string EmpNo { get; set; }
  213. }
  214. public class TimeTableData
  215. {
  216. public string AcademicYearNo { get; set; }
  217. public string Semester { get; set; }
  218. public string StartDate { get; set; }
  219. public string EndDate { get; set; }
  220. public List<ClassDataList> ClassDataList { get; set; }
  221. }
  222. public class ClassDataList
  223. {
  224. public string ClassNo { get; set; }
  225. public string ClassName { get; set; }
  226. public string LessonSortNo { get; set; }
  227. public List<TwoDevelopment.EducationalAdministration.TimeTable> TimeTableList { get; set; }
  228. }
  229. }