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.
 
 
 
 
 
 

318 lines
13 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 : BaseApi
  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. Get["/weeklist"] = GetWeeksData;
  25. Get["/currentweek"] = GetCurrentWeek;
  26. }
  27. private ArrangeLessonTermIBLL arrangeLessonTermIBLL = new ArrangeLessonTermBLL();
  28. private ArrangeLessonTermOfElectiveIBLL arrangeLessonTermOfElectiveIBLL = new ArrangeLessonTermOfElectiveBLL();
  29. private StuAttendanceLeaveIBLL stuAttendanceLeaveIBLL = new StuAttendanceLeaveBLL();
  30. private StuAttendanceIBLL stuAttendanceIBLL = new StuAttendanceBLL();
  31. public class WeekDate
  32. {
  33. public int week { get; set; }
  34. public string startdate { get; set; }
  35. public string enddate { get; set; }
  36. public string textweek { get; set; }
  37. }
  38. public Response GetWeeksData(dynamic _)
  39. {
  40. var weekdatelist = new List<WeekDate>();
  41. var yearsemester = Common.GetSemesterAndYear();
  42. var arrangelessonlist = arrangeLessonTermIBLL.GetListForTimeTable("{\"AcademicYearNo\":\"" + yearsemester.AcademicYearShort + "\",\"Semester\":\"" + yearsemester.Semester + "\"}").OrderBy(m => m.LessonDate);
  43. if (arrangelessonlist.Any())
  44. {
  45. var firstday = arrangelessonlist.First();
  46. var lastday = arrangelessonlist.Last();
  47. var monday = firstday.LessonDate.Value.AddDays(-Convert.ToInt32(firstday.LessonDate.Value.DayOfWeek) + 1);
  48. var sunday = lastday.LessonDate.Value.AddDays(7 - Convert.ToInt32(lastday.LessonDate.Value.DayOfWeek));
  49. //总周数
  50. var weekCount = Math.Ceiling(Convert.ToDouble((sunday - monday).Days + 1) / 7);
  51. for (var i = 0; i < weekCount; i++)
  52. {
  53. var wentity = new WeekDate();
  54. wentity.week = i + 1;
  55. wentity.startdate = monday.AddDays(i * 7).ToString("yyyy-MM-dd");
  56. wentity.enddate = monday.AddDays(i * 7 + 6).ToString("yyyy-MM-dd");
  57. wentity.textweek = "第" + wentity.week + "周 (" + wentity.startdate + "~" + wentity.enddate + ")";
  58. weekdatelist.Add(wentity);
  59. }
  60. return Success(weekdatelist);
  61. }
  62. else
  63. return Success(new { });
  64. }
  65. /// <summary>
  66. /// 获取当前日期是第几周
  67. /// </summary>
  68. /// <returns></returns>
  69. public Response GetCurrentWeek(dynamic _)
  70. {
  71. var yearsemester = Common.GetSemesterAndYear();
  72. var arrangelessonlist = arrangeLessonTermIBLL.GetListForTimeTable("{\"AcademicYearNo\":\"" + yearsemester.AcademicYearShort + "\",\"Semester\":\"" + yearsemester.Semester + "\"}").OrderBy(m => m.LessonDate);
  73. if (arrangelessonlist.Any())
  74. {
  75. var firstday = arrangelessonlist.First();
  76. var lastday = arrangelessonlist.Last();
  77. var monday = firstday.LessonDate.Value.AddDays(-(Convert.ToInt32(firstday.LessonDate.Value.DayOfWeek) == 0 ? 7 : Convert.ToInt32(firstday.LessonDate.Value.DayOfWeek)) + 1);
  78. var sunday = lastday.LessonDate.Value.AddDays(7 - (Convert.ToInt32(lastday.LessonDate.Value.DayOfWeek) == 0 ? 7 : Convert.ToInt32(lastday.LessonDate.Value.DayOfWeek)));
  79. var currentweek = Util.Time.GetWeekOfDay(monday, sunday);
  80. return Success(new {currentweek});
  81. }
  82. return Success(new {currentweek=1});
  83. }
  84. /// <summary>
  85. /// 课程表【教师功能、学生功能】
  86. /// </summary>
  87. /// <param name="_"></param>
  88. /// <returns></returns>
  89. public Response GetList(dynamic _)
  90. {
  91. var param = this.GetReqData<TimeParameter>();
  92. var timeTableList = new List<TwoDevelopment.EducationalAdministration.TimeTable>();
  93. //课程表
  94. var data = arrangeLessonTermIBLL.GetTimeTable(userInfo.account, userInfo.Description, param.StartDate, param.EndDate);
  95. timeTableList.AddRange(data);
  96. //选修课课程表
  97. var dataOfElective = arrangeLessonTermOfElectiveIBLL.GetTimeTable(userInfo.account, userInfo.Description, param.StartDate, param.EndDate);
  98. timeTableList.AddRange(dataOfElective);
  99. var leaveList = stuAttendanceLeaveIBLL.GetList();
  100. foreach (var item in timeTableList)
  101. {
  102. item.LeaveType = leaveList.Any(c => c.LessonNo == item.LessonNo && c.StuNo == userInfo.account && c.LessonDate == item.LessonDate && c.LessonTime == item.LessonTime) ? "1" : "0";
  103. item.IsCheck = leaveList.FirstOrDefault(c => c.LessonNo == item.LessonNo && c.StuNo == userInfo.account && c.LessonDate == item.LessonDate && c.LessonTime == item.LessonTime)?.IsCheck;
  104. }
  105. return Success(timeTableList);
  106. }
  107. /// <summary>
  108. /// 获取本堂课的学生出勤信息
  109. /// </summary>
  110. /// <param name="_"></param>
  111. /// <returns></returns>
  112. public Response GetStuInfo(dynamic _)
  113. {
  114. var param = this.GetReqData<TwoDevelopment.EducationalAdministration.TimeTable>();
  115. var result = stuAttendanceIBLL.GetStuInfo(param.AcademicYear, param.Semester, param.LessonNo, param.EmpNo, param.ClassRoomNo, param.LessonTime, param.LessonDate, param.TeachClassNo);
  116. var date = Convert.ToDateTime(param.LessonDate).ToString("yyyy-MM-dd");
  117. var time = NumberToChinese(param.LessonTime.Substring(1, 1));
  118. if (result.Count > 0)
  119. {
  120. var shouldArrive = result.Count;
  121. var turnTo = result.Count(a => a.AttendOrNo == "是");
  122. var classRoomName = param.ClassroomName;
  123. var className = result.FirstOrDefault().ClassName;
  124. var lessonName = result.FirstOrDefault().LessonName;
  125. return Success(new { result, date, time, shouldArrive, turnTo, classRoomName, className, lessonName });
  126. }
  127. else
  128. {
  129. return Success(new { result, date, time });
  130. }
  131. }
  132. public Response GetStuLessonInfo(dynamic _)
  133. {
  134. var lessonInfos = stuAttendanceIBLL.GetStuLessonInfo(userInfo.account);
  135. var empNos = lessonInfos.Select(a => a.EmpNo).ToList();
  136. var lessonTerms = arrangeLessonTermIBLL.GetListByEmpNo(empNos);
  137. var list = lessonInfos.Select(a => new
  138. {
  139. a.LessonName,
  140. LessonDate = Convert.ToDateTime(a.LessonDate).ToString("yyyy-MM-dd"),
  141. Teacher = lessonTerms.FirstOrDefault(b => b.EmpNo == a.EmpNo).EmpName,
  142. a.LessonTime,
  143. a.EmpNo,
  144. a.ClassRoomName,
  145. a.Sort
  146. }).ToList();
  147. var weeks = list.GroupBy(a => a.LessonDate).ToList();
  148. List<object> results = new List<object>();
  149. foreach (var item in weeks)
  150. {
  151. var weekList = list.Where(a => a.LessonDate == item.Key).ToList();
  152. var week = weekList[0].LessonTime.Substring(0, 1);
  153. var result = new { week, weekList };
  154. results.Add(result);
  155. }
  156. return Success(results);
  157. }
  158. /// <summary>
  159. /// 全院课程表【按班级分组】
  160. /// </summary>
  161. /// <param name="_"></param>
  162. /// <returns></returns>
  163. private Response GetTimeTableData(dynamic _)
  164. {
  165. var param = this.GetReq<TimeParameter>();
  166. TimeTableData result = new TimeTableData();
  167. //开始时间
  168. var startdate = string.IsNullOrEmpty(param.StartDate) ? DateTime.Today : Convert.ToDateTime(param.StartDate);
  169. var startDate = Common.CalculateFirstDateOfWeek(startdate).ToString("yyyy-MM-dd");
  170. var endDate = Common.CalculateLastDateOfWeek(startdate).ToString("yyyy-MM-dd");
  171. result.StartDate = startDate;
  172. result.EndDate = endDate;
  173. var semesterAndYear = Common.GetSemesterAndYear(startDate);
  174. result.AcademicYearNo = semesterAndYear.AcademicYearLong;
  175. result.Semester = semesterAndYear.Semester;
  176. //课程表数据
  177. var timeTableList = new List<Learun.Application.TwoDevelopment.EducationalAdministration.TimeTable>();
  178. //必修课课程表
  179. var data = arrangeLessonTermIBLL.GetTimeTableInEducation(startDate, endDate, param.ClassNo, param.EmpNo, "", "");
  180. timeTableList.AddRange(data);
  181. //选修课课程表
  182. var dataOfElective = arrangeLessonTermOfElectiveIBLL.GetTimeTableInEducation(startDate, endDate, param.ClassNo, param.EmpNo, "");
  183. timeTableList.AddRange(dataOfElective);
  184. var dataTemp = timeTableList.GroupBy(x => new { x.TeachClassNo, x.ClassName, x.LessonSortNo }).Select(x => new ClassDataList()
  185. {
  186. ClassNo = x.Key.TeachClassNo,
  187. ClassName = x.Key.ClassName,
  188. LessonSortNo = x.Key.LessonSortNo,
  189. TimeTableList = x.Select(y => new TwoDevelopment.EducationalAdministration.TimeTable()
  190. {
  191. AcademicYear = y.AcademicYear,
  192. Semester = y.Semester,
  193. DeptNo = y.DeptNo,
  194. MajorNo = y.MajorNo,
  195. F_SchoolId = y.F_SchoolId,
  196. LessonNo = y.LessonNo,
  197. LessonName = y.LessonName,
  198. LessonDate = y.LessonDate,
  199. LessonTime = y.LessonTime,
  200. EmpNo = y.EmpNo,
  201. EmpName = y.EmpName,
  202. TeachClassNo = y.TeachClassNo,
  203. ClassName = y.ClassName,
  204. ClassRoomNo = y.ClassRoomNo,
  205. ClassroomName = y.ClassroomName,
  206. LessonSortNo = y.LessonSortNo
  207. }).OrderBy(a => a.LessonTime.Substring(0, 1)).ThenBy(a => a.LessonTime.Substring(1)).ToList()
  208. }).OrderBy(x => x.LessonSortNo).ThenBy(x => x.ClassNo).ToList();
  209. result.ClassDataList = dataTemp;
  210. return Success(result);
  211. }
  212. /// <summary>
  213. /// 数字转中文
  214. /// </summary>
  215. /// <param name="number">eg: 22</param>
  216. /// <returns></returns>
  217. public string NumberToChinese(string number)
  218. {
  219. string res = string.Empty;
  220. switch (number)
  221. {
  222. case "1":
  223. res = "一";
  224. break;
  225. case "2":
  226. res = "二";
  227. break;
  228. case "3":
  229. res = "三";
  230. break;
  231. case "4":
  232. res = "四";
  233. break;
  234. case "5":
  235. res = "五";
  236. break;
  237. case "6":
  238. res = "六";
  239. break;
  240. case "7":
  241. res = "七";
  242. break;
  243. case "8":
  244. res = "八";
  245. break;
  246. case "9":
  247. res = "九";
  248. break;
  249. default:
  250. res = "零";
  251. break;
  252. }
  253. return res;
  254. }
  255. }
  256. public class TimeParameter
  257. {
  258. public string StartDate { get; set; }
  259. public string EndDate { get; set; }
  260. /// <summary>
  261. /// 班级编号
  262. /// </summary>
  263. public string ClassNo { get; set; }
  264. /// <summary>
  265. /// 教师编号
  266. /// </summary>
  267. public string EmpNo { get; set; }
  268. }
  269. public class TimeTableData
  270. {
  271. public string AcademicYearNo { get; set; }
  272. public string Semester { get; set; }
  273. public string StartDate { get; set; }
  274. public string EndDate { get; set; }
  275. public List<ClassDataList> ClassDataList { get; set; }
  276. }
  277. public class ClassDataList
  278. {
  279. public string ClassNo { get; set; }
  280. public string ClassName { get; set; }
  281. public string LessonSortNo { get; set; }
  282. public List<TwoDevelopment.EducationalAdministration.TimeTable> TimeTableList { get; set; }
  283. }
  284. }