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.

TimeTable.cs 19 KiB

4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449
  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["/TenDay"] = GetTenDay;
  25. }
  26. private ArrangeLessonTermIBLL arrangeLessonTermIBLL = new ArrangeLessonTermBLL();
  27. private ArrangeLessonTermOfElectiveIBLL arrangeLessonTermOfElectiveIBLL = new ArrangeLessonTermOfElectiveBLL();
  28. private StuAttendanceLeaveIBLL stuAttendanceLeaveIBLL = new StuAttendanceLeaveBLL();
  29. private StuAttendanceIBLL stuAttendanceIBLL = new StuAttendanceBLL();
  30. private EmpInfoIBLL empInfoIbll = new EmpInfoBLL();
  31. private StuInfoBasicIBLL stuInfoBasicIBLL = new StuInfoBasicBLL();
  32. private SchoolCalendarIBLL schoolCalendarIbll = new SchoolCalendarBLL();
  33. /// <summary>
  34. /// 课程表【教师功能、学生功能】
  35. /// </summary>
  36. /// <param name="_"></param>
  37. /// <returns></returns>
  38. public Response GetList(dynamic _)
  39. {
  40. var param = this.GetReqData<TimeParameter>();
  41. var timeTableList = new List<TwoDevelopment.EducationalAdministration.TimeTable>();
  42. //课程表
  43. var data = arrangeLessonTermIBLL.GetTimeTable(userInfo.account, userInfo.Description, param.StartDate, param.EndDate);
  44. timeTableList.AddRange(data);
  45. //选修课课程表
  46. var dataOfElective = arrangeLessonTermOfElectiveIBLL.GetTimeTable(userInfo.account, userInfo.Description, param.StartDate, param.EndDate);
  47. timeTableList.AddRange(dataOfElective);
  48. var leaveList = stuAttendanceLeaveIBLL.GetList();
  49. foreach (var item in timeTableList)
  50. {
  51. item.LeaveType = leaveList.Any(c => c.LessonNo == item.LessonNo && c.StuNo == userInfo.account && c.LessonDate == item.LessonDate && c.LessonTime == item.LessonTime) ? "1" : "0";
  52. item.IsCheck = leaveList.FirstOrDefault(c => c.LessonNo == item.LessonNo && c.StuNo == userInfo.account && c.LessonDate == item.LessonDate && c.LessonTime == item.LessonTime)?.IsCheck;
  53. }
  54. return Success(timeTableList);
  55. }
  56. /// <summary>
  57. /// 获取本堂课的学生出勤信息
  58. /// </summary>
  59. /// <param name="_"></param>
  60. /// <returns></returns>
  61. public Response GetStuInfo(dynamic _)
  62. {
  63. var param = this.GetReqData<TwoDevelopment.EducationalAdministration.TimeTable>();
  64. var result = stuAttendanceIBLL.GetStuInfo(param.AcademicYear, param.Semester, param.LessonNo, param.EmpNo, param.ClassRoomNo, param.LessonTime, param.LessonDate, param.TeachClassNo);
  65. var date = Convert.ToDateTime(param.LessonDate).ToString("yyyy-MM-dd");
  66. var time = NumberToChinese(param.LessonTime.Substring(1, 1));
  67. if (result.Count > 0)
  68. {
  69. var shouldArrive = result.Count;
  70. var turnTo = result.Count(a => a.AttendOrNo == "是");
  71. var classRoomName = param.ClassroomName;
  72. var className = result.FirstOrDefault().ClassName;
  73. var lessonName = result.FirstOrDefault().LessonName;
  74. return Success(new { result, date, time, shouldArrive, turnTo, classRoomName, className, lessonName });
  75. }
  76. else
  77. {
  78. return Success(new { result, date, time });
  79. }
  80. }
  81. public Response GetStuLessonInfo(dynamic _)
  82. {
  83. var param = this.GetReqData<TimeParameter>();
  84. var startdate = DateTime.Today;
  85. var startDate = Common.CalculateFirstDateOfWeek(startdate).ToString("yyyy-MM-dd");
  86. var endDate = Common.CalculateLastDateOfWeek(startdate).ToString("yyyy-MM-dd");
  87. var lessonInfos = stuAttendanceIBLL.GetStuLessonInfo("", "", "");
  88. var strAcademicYear = "";
  89. var strSemester = "";
  90. var AcademicYearShort = "";
  91. // 获取学年,学期
  92. if (!param.StartDate.IsEmpty() && !param.EndDate.IsEmpty())
  93. {
  94. var NewsemesterAndYear = Common.GetSemesterAndYear(param.StartDate);
  95. strAcademicYear = NewsemesterAndYear.AcademicYearLong;
  96. strSemester = NewsemesterAndYear.Semester;
  97. AcademicYearShort = NewsemesterAndYear.AcademicYearShort;
  98. }
  99. else
  100. {
  101. var semesterAndYear = Common.GetSemesterAndYear(startDate);
  102. strAcademicYear = semesterAndYear.AcademicYearLong;
  103. strSemester = semesterAndYear.Semester;
  104. AcademicYearShort = semesterAndYear.AcademicYearShort;
  105. }
  106. if (param.StartDate.IsEmpty() && param.EndDate.IsEmpty())
  107. {
  108. // 校历
  109. var entity = schoolCalendarIbll.GetSchoolCalendarEntityByNo(AcademicYearShort, strSemester);
  110. var StartTime = entity.StartTime.Value;
  111. //获取第几周
  112. var curWeek = WeekOfYear(startdate, entity.StartTime.Value, entity.EndTime.Value);
  113. ///获取当前周次开始时间
  114. startDate = Common.CalculateFirstDateOfWeek(StartTime.AddDays(((curWeek - 1) * 14))).ToString("yyyy-MM-dd");
  115. if (curWeek == 1 && Convert.ToDateTime(startDate) < StartTime)//判断第几周
  116. {
  117. startDate = StartTime.ToString("yyyy-MM-dd");
  118. }
  119. endDate = Common.CalculateFirstDateOfWeek(StartTime.AddDays(((curWeek - 1) * 14))).AddDays(13).ToString("yyyy-MM-dd");
  120. param.StartDate = startDate;
  121. param.EndDate = endDate;
  122. }
  123. lessonInfos = stuAttendanceIBLL.GetStuLessonInfo(userInfo.account, param.StartDate, param.EndDate);
  124. var empNos = lessonInfos.Select(a => a.EmpNo).ToList();
  125. var lessonTerms = arrangeLessonTermIBLL.GetListByEmpNo(empNos);
  126. var list = lessonInfos.Select(a => new
  127. {
  128. a.LessonName,
  129. LessonDate = Convert.ToDateTime(a.LessonDate).ToString("yyyy-MM-dd"),
  130. Teacher = lessonTerms.FirstOrDefault(b => b.EmpNo == a.EmpNo)?.EmpName,
  131. a.LessonTime,
  132. a.EmpNo,
  133. a.ClassRoomNo,
  134. a.ClassRoomName,
  135. a.ClassNo,
  136. a.ClassName,
  137. a.Sort,
  138. a.AttendOrNo
  139. }).ToList();
  140. var weeks = list.GroupBy(a => a.LessonDate).ToList();
  141. List<object> results = new List<object>();
  142. foreach (var item in weeks)
  143. {
  144. var weekList = list.Where(a => a.LessonDate == item.Key).ToList();
  145. var week = weekList[0].LessonTime.Substring(0, 1);
  146. var result = new { week, weekList };
  147. results.Add(result);
  148. }
  149. return Success(new { results, schoolName = "课程表", semester = $"{strAcademicYear}学年度 第{strSemester}学期", startDate = param.StartDate, endDate = param.EndDate });
  150. }
  151. /// <summary>
  152. /// 全院课程表【按班级分组】
  153. /// </summary>
  154. /// <param name="_"></param>
  155. /// <returns></returns>
  156. private Response GetTimeTableData(dynamic _)
  157. {
  158. var param = this.GetReq<TimeParameter>();
  159. TimeTableData result = new TimeTableData();
  160. //开始时间
  161. var startdate = string.IsNullOrEmpty(param.StartDate) ? DateTime.Today : Convert.ToDateTime(param.StartDate);
  162. var startDate = Common.CalculateFirstDateOfWeek(startdate).ToString("yyyy-MM-dd");
  163. var endDate = Common.CalculateLastDateOfWeek(startdate).ToString("yyyy-MM-dd");
  164. result.StartDate = startDate;
  165. result.EndDate = endDate;
  166. var semesterAndYear = Common.GetSemesterAndYear(startDate);
  167. result.AcademicYearNo = semesterAndYear.AcademicYearLong;
  168. result.Semester = semesterAndYear.Semester;
  169. //课程表数据
  170. var timeTableList = new List<Learun.Application.TwoDevelopment.EducationalAdministration.TimeTable>();
  171. //必修课课程表
  172. var data = arrangeLessonTermIBLL.GetTimeTableInEducation(startDate, endDate, param.ClassNo, param.EmpNo, "");
  173. timeTableList.AddRange(data);
  174. //选修课课程表
  175. var dataOfElective = arrangeLessonTermOfElectiveIBLL.GetTimeTableInEducation(startDate, endDate, param.ClassNo, param.EmpNo, "");
  176. timeTableList.AddRange(dataOfElective);
  177. var dataTemp = timeTableList.GroupBy(x => new { x.TeachClassNo, x.ClassName, x.LessonSortNo }).Select(x => new ClassDataList()
  178. {
  179. ClassNo = x.Key.TeachClassNo,
  180. ClassName = x.Key.ClassName,
  181. LessonSortNo = x.Key.LessonSortNo,
  182. TimeTableList = x.Select(y => new TwoDevelopment.EducationalAdministration.TimeTable()
  183. {
  184. AcademicYear = y.AcademicYear,
  185. Semester = y.Semester,
  186. DeptNo = y.DeptNo,
  187. MajorNo = y.MajorNo,
  188. F_SchoolId = y.F_SchoolId,
  189. LessonNo = y.LessonNo,
  190. LessonName = y.LessonName,
  191. LessonDate = y.LessonDate,
  192. LessonTime = y.LessonTime,
  193. EmpNo = y.EmpNo,
  194. EmpName = y.EmpName,
  195. TeachClassNo = y.TeachClassNo,
  196. ClassName = y.ClassName,
  197. ClassRoomNo = y.ClassRoomNo,
  198. ClassroomName = y.ClassroomName,
  199. LessonSortNo = y.LessonSortNo
  200. }).OrderBy(a => a.LessonTime.Substring(0, 1)).ThenBy(a => a.LessonTime.Substring(1)).ToList()
  201. }).OrderBy(x => x.LessonSortNo).ThenBy(x => x.ClassNo).ToList();
  202. result.ClassDataList = dataTemp;
  203. return Success(result);
  204. }
  205. /// <summary>
  206. /// 课程表【教师功能、学生功能】
  207. /// </summary>
  208. /// <param name="_"></param>
  209. /// <returns></returns>
  210. public Response GetTenDay(dynamic _)
  211. {
  212. var param = this.GetReqData<TimeParameter>();
  213. var startdate = DateTime.Today;
  214. var startDate = Common.CalculateFirstDateOfWeek(startdate).ToString("yyyy-MM-dd");
  215. var endDate = Common.CalculateLastDateOfWeek(startdate).ToString("yyyy-MM-dd");
  216. // 获取学年,学期
  217. var strAcademicYear = "";
  218. var strSemester = "";
  219. var AcademicYearShort = "";
  220. if (!param.StartDate.IsEmpty())
  221. {
  222. var NewsemesterAndYear = Common.GetSemesterAndYear(param.StartDate);
  223. strAcademicYear = NewsemesterAndYear.AcademicYearLong;
  224. strSemester = NewsemesterAndYear.Semester;
  225. AcademicYearShort = NewsemesterAndYear.AcademicYearShort;
  226. }
  227. else
  228. {
  229. var semesterAndYear = Common.GetSemesterAndYear(startDate);
  230. strAcademicYear = semesterAndYear.AcademicYearLong;
  231. strSemester = semesterAndYear.Semester;
  232. AcademicYearShort = semesterAndYear.AcademicYearShort;
  233. }
  234. if (param.StartDate.IsEmpty() && param.EndDate.IsEmpty())
  235. {
  236. // 校历
  237. var entity = schoolCalendarIbll.GetSchoolCalendarEntityByNo(AcademicYearShort, strSemester);
  238. var StartTime = entity.StartTime.Value;
  239. //获取第几周
  240. var curWeek = WeekOfYear(startdate, entity.StartTime.Value, entity.EndTime.Value);
  241. ///获取当前周次开始时间
  242. startDate = Common.CalculateFirstDateOfWeek(StartTime.AddDays(((curWeek - 1) * 14))).ToString("yyyy-MM-dd");
  243. if (curWeek == 1 && Convert.ToDateTime(startDate) < StartTime)//判断第几周
  244. {
  245. startDate = StartTime.ToString("yyyy-MM-dd");
  246. }
  247. endDate = Common.CalculateFirstDateOfWeek(StartTime.AddDays(((curWeek - 1) * 14))).AddDays(13).ToString("yyyy-MM-dd");
  248. param.StartDate = startDate;
  249. param.EndDate = endDate;
  250. }
  251. var Data = new List<TwoDevelopment.EducationalAdministration.TimeTable>();
  252. if (param.Description == "学生")
  253. {
  254. var Stulist = stuInfoBasicIBLL.GetAllList().Where(x => x.StuNo == param.Account).FirstOrDefault();
  255. if (Stulist != null)
  256. {
  257. Data = arrangeLessonTermIBLL.GetTimeTableInEducation(param.StartDate, param.EndDate, Stulist.ClassNo, "", "").ToList();
  258. }
  259. }
  260. else if (param.Description == "教师")
  261. {
  262. //教师
  263. var empInfo = empInfoIbll.GetAllList().Where(x => x.EmpNo == param.Account).FirstOrDefault().EmpNo;
  264. if (empInfo != null)
  265. {
  266. Data = arrangeLessonTermIBLL.GetTimeTableInEducation(param.StartDate, param.EndDate, "", param.Account, "").ToList();
  267. }
  268. }
  269. var formatData = from d in Data.AsEnumerable()
  270. let tt = d.LessonTime.Split('-')[0]
  271. group d by tt into g
  272. orderby g.Key
  273. select new
  274. {
  275. time = g.Key,
  276. list = from e in Data.AsEnumerable()
  277. let ee = e.LessonTime.Split('-')[0]
  278. where ee == g.Key
  279. select new
  280. {
  281. ALTId = e.ALTId,
  282. day = e.LessonTime.Split('-')[0],
  283. jc = e.LessonTime.Split('-')[1],
  284. curriculum = e.LessonSortNo == "2" ? e.LessonName + "[选修]" : e.LessonName,
  285. teacher = e?.EmpName,
  286. classRoom = string.IsNullOrEmpty(e.ClassroomName) ? "" : e.ClassroomName.Trim(),
  287. academicyear = e.AcademicYear,
  288. semester = e.Semester,
  289. lessonNo = e?.LessonNo,
  290. teachClassNo = e?.TeachClassNo,
  291. empno = e?.EmpNo,
  292. lessonTime = e.LessonTime,
  293. lessonDate = e.LessonDate.ToString("yyyy-MM-dd"),
  294. classRoomNo = string.IsNullOrEmpty(e.ClassRoomNo) ? "" : e.ClassRoomNo.Trim(),
  295. lessonSortNo = e.LessonSortNo,
  296. e?.OLPEId,
  297. className = string.IsNullOrEmpty(e.ClassName) ? "" : e.ClassName
  298. }
  299. }
  300. ;
  301. var result = new
  302. { schoolName = "课程表", semester = $"{strAcademicYear}学年度 第{strSemester}学期", startDate = param.StartDate, endDate = param.EndDate, weekList = formatData };
  303. return Success(result);
  304. }
  305. /// <summary>
  306. /// 数字转中文
  307. /// </summary>
  308. /// <param name="number">eg: 22</param>
  309. /// <returns></returns>
  310. public string NumberToChinese(string number)
  311. {
  312. string res = string.Empty;
  313. switch (number)
  314. {
  315. case "1":
  316. res = "一";
  317. break;
  318. case "2":
  319. res = "二";
  320. break;
  321. case "3":
  322. res = "三";
  323. break;
  324. case "4":
  325. res = "四";
  326. break;
  327. case "5":
  328. res = "五";
  329. break;
  330. case "6":
  331. res = "六";
  332. break;
  333. case "7":
  334. res = "七";
  335. break;
  336. case "8":
  337. res = "八";
  338. break;
  339. case "9":
  340. res = "九";
  341. break;
  342. default:
  343. res = "零";
  344. break;
  345. }
  346. return res;
  347. }
  348. /// <summary>
  349. /// 换算周次
  350. /// </summary>
  351. /// <param name="curDay"></param>
  352. /// <param name="startTime"></param>
  353. /// <param name="endTime"></param>
  354. /// <returns></returns>
  355. private static int WeekOfYear(DateTime curDay, DateTime startTime, DateTime endTime)
  356. {
  357. int firstdayofweek = Convert.ToInt32(startTime.DayOfWeek);
  358. var startDate = DateTime.Parse(Common.CalculateFirstDateOfWeek(startTime).ToString("yyyy-MM-dd"));
  359. int k = Convert.ToInt32(startTime.DayOfWeek);//得到开始时间的第一天是周几
  360. int days = curDay.Subtract(startTime).Days;
  361. //int days = curDay.DayOfYear;
  362. int daysOutOneWeek = days - (14 - firstdayofweek);
  363. if (daysOutOneWeek <= 0)
  364. {
  365. return 1;
  366. }
  367. else
  368. {
  369. int weeks = daysOutOneWeek / 14;
  370. if (daysOutOneWeek % 14 != 0)
  371. weeks++;
  372. return weeks + 1;
  373. }
  374. }
  375. }
  376. public class TimeParameter
  377. {
  378. public string StartDate { get; set; }
  379. public string EndDate { get; set; }
  380. /// <summary>
  381. /// 班级编号
  382. /// </summary>
  383. public string ClassNo { get; set; }
  384. /// <summary>
  385. /// 教师编号
  386. /// </summary>
  387. public string EmpNo { get; set; }
  388. public string Description { get; set; }
  389. public string Account { get; set; }
  390. }
  391. public class TimeTableData
  392. {
  393. public string AcademicYearNo { get; set; }
  394. public string Semester { get; set; }
  395. public string StartDate { get; set; }
  396. public string EndDate { get; set; }
  397. public List<ClassDataList> ClassDataList { get; set; }
  398. }
  399. public class ClassDataList
  400. {
  401. public string ClassNo { get; set; }
  402. public string ClassName { get; set; }
  403. public string LessonSortNo { get; set; }
  404. public List<TwoDevelopment.EducationalAdministration.TimeTable> TimeTableList { get; set; }
  405. }
  406. }