您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
 
 
 
 
 
 

259 行
9.9 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 param = this.GetReqData<TimeParameter>();
  80. var lessonInfos = stuAttendanceIBLL.GetStuLessonInfo(userInfo.account,param.StartDate,param.EndDate);
  81. var empNos = lessonInfos.Select(a => a.EmpNo).ToList();
  82. var lessonTerms = arrangeLessonTermIBLL.GetListByEmpNo(empNos);
  83. var list = lessonInfos.Select(a => new
  84. {
  85. a.LessonName,
  86. LessonDate = Convert.ToDateTime(a.LessonDate).ToString("yyyy-MM-dd"),
  87. Teacher = lessonTerms.FirstOrDefault(b => b.EmpNo == a.EmpNo)?.EmpName,
  88. a.LessonTime,
  89. a.EmpNo,
  90. a.ClassRoomName,
  91. a.Sort
  92. }).ToList();
  93. var weeks = list.GroupBy(a => a.LessonDate).ToList();
  94. List<object> results = new List<object>();
  95. foreach (var item in weeks)
  96. {
  97. var weekList = list.Where(a => a.LessonDate == item.Key).ToList();
  98. var week = weekList[0].LessonTime.Substring(0, 1);
  99. var result = new { week, weekList };
  100. results.Add(result);
  101. }
  102. return Success(results);
  103. }
  104. /// <summary>
  105. /// 全院课程表【按班级分组】
  106. /// </summary>
  107. /// <param name="_"></param>
  108. /// <returns></returns>
  109. private Response GetTimeTableData(dynamic _)
  110. {
  111. var param = this.GetReq<TimeParameter>();
  112. TimeTableData result = new TimeTableData();
  113. //开始时间
  114. var startdate = string.IsNullOrEmpty(param.StartDate) ? DateTime.Today : Convert.ToDateTime(param.StartDate);
  115. var startDate = Common.CalculateFirstDateOfWeek(startdate).ToString("yyyy-MM-dd");
  116. var endDate = Common.CalculateLastDateOfWeek(startdate).ToString("yyyy-MM-dd");
  117. result.StartDate = startDate;
  118. result.EndDate = endDate;
  119. var semesterAndYear = Common.GetSemesterAndYear(startDate);
  120. result.AcademicYearNo = semesterAndYear.AcademicYearLong;
  121. result.Semester = semesterAndYear.Semester;
  122. //课程表数据
  123. var timeTableList = new List<Learun.Application.TwoDevelopment.EducationalAdministration.TimeTable>();
  124. //必修课课程表
  125. var data = arrangeLessonTermIBLL.GetTimeTableInEducation(startDate, endDate, param.ClassNo, param.EmpNo, "");
  126. timeTableList.AddRange(data);
  127. //选修课课程表
  128. var dataOfElective = arrangeLessonTermOfElectiveIBLL.GetTimeTableInEducation(startDate, endDate, param.ClassNo, param.EmpNo, "");
  129. timeTableList.AddRange(dataOfElective);
  130. var dataTemp = timeTableList.GroupBy(x => new { x.TeachClassNo, x.ClassName, x.LessonSortNo }).Select(x => new ClassDataList()
  131. {
  132. ClassNo = x.Key.TeachClassNo,
  133. ClassName = x.Key.ClassName,
  134. LessonSortNo = x.Key.LessonSortNo,
  135. TimeTableList = x.Select(y => new TwoDevelopment.EducationalAdministration.TimeTable()
  136. {
  137. AcademicYear = y.AcademicYear,
  138. Semester = y.Semester,
  139. DeptNo = y.DeptNo,
  140. MajorNo = y.MajorNo,
  141. F_SchoolId = y.F_SchoolId,
  142. LessonNo = y.LessonNo,
  143. LessonName = y.LessonName,
  144. LessonDate = y.LessonDate,
  145. LessonTime = y.LessonTime,
  146. EmpNo = y.EmpNo,
  147. EmpName = y.EmpName,
  148. TeachClassNo = y.TeachClassNo,
  149. ClassName = y.ClassName,
  150. ClassRoomNo = y.ClassRoomNo,
  151. ClassroomName = y.ClassroomName,
  152. LessonSortNo = y.LessonSortNo
  153. }).OrderBy(a => a.LessonTime.Substring(0, 1)).ThenBy(a => a.LessonTime.Substring(1)).ToList()
  154. }).OrderBy(x => x.LessonSortNo).ThenBy(x => x.ClassNo).ToList();
  155. result.ClassDataList = dataTemp;
  156. return Success(result);
  157. }
  158. /// <summary>
  159. /// 数字转中文
  160. /// </summary>
  161. /// <param name="number">eg: 22</param>
  162. /// <returns></returns>
  163. public string NumberToChinese(string number)
  164. {
  165. string res = string.Empty;
  166. switch (number)
  167. {
  168. case "1":
  169. res = "一";
  170. break;
  171. case "2":
  172. res = "二";
  173. break;
  174. case "3":
  175. res = "三";
  176. break;
  177. case "4":
  178. res = "四";
  179. break;
  180. case "5":
  181. res = "五";
  182. break;
  183. case "6":
  184. res = "六";
  185. break;
  186. case "7":
  187. res = "七";
  188. break;
  189. case "8":
  190. res = "八";
  191. break;
  192. case "9":
  193. res = "九";
  194. break;
  195. default:
  196. res = "零";
  197. break;
  198. }
  199. return res;
  200. }
  201. }
  202. public class TimeParameter
  203. {
  204. public string StartDate { get; set; }
  205. public string EndDate { get; set; }
  206. /// <summary>
  207. /// 班级编号
  208. /// </summary>
  209. public string ClassNo { get; set; }
  210. /// <summary>
  211. /// 教师编号
  212. /// </summary>
  213. public string EmpNo { get; set; }
  214. }
  215. public class TimeTableData
  216. {
  217. public string AcademicYearNo { get; set; }
  218. public string Semester { get; set; }
  219. public string StartDate { get; set; }
  220. public string EndDate { get; set; }
  221. public List<ClassDataList> ClassDataList { get; set; }
  222. }
  223. public class ClassDataList
  224. {
  225. public string ClassNo { get; set; }
  226. public string ClassName { get; set; }
  227. public string LessonSortNo { get; set; }
  228. public List<TwoDevelopment.EducationalAdministration.TimeTable> TimeTableList { get; set; }
  229. }
  230. }