Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.
 
 
 
 
 
 

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