CourseBase.cs 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel.DataAnnotations;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. namespace TEAMModelOS.SDK.Models
  8. {
  9. /*
  10. //课程基础信息
  11. "courseBase": {
  12. "id": " uuid1",
  13. "code": "CourseBase-hbcn",
  14. "pk": "CourseBase",
  15. "name": "语文课",
  16. "subject": {
  17. "id": "科目id1",
  18. "name": "高数"
  19. },
  20. "period": {
  21. "id": "学段id1",
  22. "name": "大学"
  23. },
  24. "major": { //专业信息在K12可不设置。
  25. "id": "专业id1",
  26. "name": "软件工程"
  27. },
  28. "scope": "school",
  29. "desc": "软件工程专业-高等数学",
  30. "no": "A101",
  31. "creatorId": "1595321354",
  32. "school": "hbcn",
  33. "color": "red", //用于标记课程表的排课颜色
  34. "grades": [0,1,2], //年级
  35. "status": 1
  36. }
  37. */
  38. /// <summary>
  39. /// 课程基础信息
  40. /// </summary>
  41. public class CourseBase : CosmosEntity
  42. { /// <summary>
  43. /// 课程名称
  44. /// </summary>
  45. [Required(ErrorMessage = "{0} 必须填写")]
  46. public string name { get; set; }
  47. /// <summary>
  48. /// 科目
  49. /// </summary>
  50. public IdName subject { get; set; }
  51. /// <summary>
  52. /// 学段
  53. /// </summary>
  54. public IdName period { get; set; }
  55. /// <summary>
  56. /// 专业 不是必须的。
  57. /// </summary>
  58. public IdName major { get; set; }
  59. public string scope { get; set; }
  60. /// <summary>
  61. /// 描述
  62. /// </summary>
  63. public string desc { get; set; }
  64. /// <summary>
  65. /// 课程编号
  66. /// </summary>
  67. public string no { get; set; }
  68. /// <summary>
  69. /// 创建者的id
  70. /// </summary>
  71. public string creatorId { get; set; }
  72. /// <summary>
  73. /// 创建者的id
  74. /// </summary>
  75. public string creatorName { get; set; }
  76. /// <summary>
  77. /// 创建者的id
  78. /// </summary>
  79. public string creatorPicture { get; set; }
  80. /// <summary>
  81. /// 学校编码
  82. /// </summary>
  83. public string school { get; set; }
  84. /// <summary>
  85. /// 颜色,课表标记颜色
  86. /// </summary>
  87. public string color { get; set; }
  88. /// <summary>
  89. /// 年级,此处的下标是从0-n开始的。
  90. /// 注:比如高二可能会将高三的课程学完,则该高三的课程的学年级应该是手动处理为高中二年级。不区分学期的目的,也是可能存在提前一学期学完第二学期的课程。
  91. /// </summary>
  92. // public HashSet<int> grades { get; set; } = new HashSet<int>();
  93. public int grade { get; set; }
  94. /// <summary>
  95. /// 状态
  96. /// </summary>
  97. public int status { get; set; } = 1;
  98. public int count { get; set; }
  99. }
  100. /*
  101. //课程排课任务
  102. "courseTask": {
  103. //年份+学期,2022-2023第一学期
  104. "id": " 2022-semesterId-courseId",
  105. "code": "CourseTask-hbcn",
  106. "pk": "CourseTask",
  107. "expire": 1577808000000,//默认-1 永不过期,学校的课程则自动根据学期的时间进行设置。
  108. "courseId": "courseIduuid1",//课程id
  109. "year": 2022,//课程所属年份
  110. "semesterId": "学期id",
  111. "weekCount": 20,//课程持续多少周,-1未设定
  112. "timeCount": 10,//课程一周有多少堂课,-1未设定
  113. "schedules": [
  114. {
  115. "roomId": "物理教室id",//
  116. "groupId": "名单id",
  117. "type": "名单类型-class行政班,teach教学班",
  118. "teacherId": "1595321354",
  119. //times可不设置,不设置也不影响HiTeach使用,只是不能展示为课表模式,只能是课程任务列表模式。
  120. "times": [
  121. {
  122. "id": "学校作息时间id",
  123. "week": "MON",//星期几
  124. "mode": "all全部,single单周,double双周,custom自定义",
  125. "index": [
  126. 1,
  127. 5,
  128. 8,
  129. 15
  130. ]
  131. }
  132. ]
  133. }
  134. ]
  135. }
  136. */
  137. /// <summary>
  138. /// 课程任务
  139. /// 学校课程
  140. /// id 2022-semesterId-courseId
  141. /// code CourseTask-hbcn
  142. /// 个人课程
  143. /// id $"{_courseId}";
  144. /// $"CourseTask";
  145. /// </summary>
  146. public class CourseTask : CosmosEntity
  147. {
  148. /// <summary>
  149. /// 过期时间,-1永不过期, 1577808000000 2020-01-01。 学校的课程则自动根据学期的时间变化。
  150. /// </summary>
  151. public long expire { get; set; } = -1;
  152. /// <summary>
  153. /// 课程的id
  154. /// </summary>
  155. public string courseId { get; set; }
  156. /// <summary>
  157. /// 课表所属年份
  158. /// </summary>
  159. public int year { get; set; }
  160. /// <summary>
  161. /// semesterId 学期id
  162. /// </summary>
  163. public string semesterId { get; set; }
  164. public List<ScheduleTask> schedules { get; set; } = new List<ScheduleTask>();
  165. /// <summary>
  166. /// 课程持续多少周,-1未设定
  167. /// </summary>
  168. public int weekCount { get; set; } = -1;
  169. /// <summary>
  170. /// 课程一周有多少堂课,-1未设定
  171. /// </summary>
  172. public int timeCount { get; set; } = -1;
  173. }
  174. public class ScheduleTask
  175. {
  176. /// <summary>
  177. /// 教室id
  178. /// </summary>
  179. public string roomId { get; set; }
  180. /// <summary>
  181. /// 班级名单id: 行政班|教学班
  182. /// </summary>
  183. public string groupId { get; set; }
  184. /// <summary>
  185. /// type class行政班 teach教学班
  186. /// </summary>
  187. public string type { get; set; }
  188. /// <summary>
  189. /// 教师的醍摩豆id
  190. /// </summary>
  191. public string teacherId { get; set; }
  192. /// <summary>
  193. /// 排课时间表
  194. /// </summary>
  195. public List<ScheduleTime> times { get; set; } = new List<ScheduleTime>();
  196. /// <summary>
  197. /// 个人课程,讲座,研讨会,直播开始时间。用通知预报开始时间。
  198. /// </summary>
  199. public long startTime { get; set; }
  200. /// <summary>
  201. /// 开课通知内容,比如临时调整上课地点,或需要准备的资料,开课主讲内容等。
  202. /// </summary>
  203. public string notice { get; set; }
  204. /// <summary>
  205. /// 设计该字段的目的在于可能会出现教师个人课程,使用某一学校名单进行上课,或者教师临时自己开课,使用学校名单。
  206. /// 在个人课程展示这个的时候,只展示教师登录所在的学校,而且要检查当前名单是否与学校一致
  207. /// </summary>
  208. public string school { get; set; }
  209. /// <summary>
  210. /// 助教id集合
  211. /// </summary>
  212. public HashSet<string> assistants { get; set; } = new HashSet<string>();
  213. }
  214. public class ScheduleTaskDto
  215. {
  216. /// <summary>
  217. /// 教室id
  218. /// </summary>
  219. public string roomId { get; set; }
  220. /// <summary>
  221. /// 班级名单id: 行政班|教学班
  222. /// </summary>
  223. public string groupId { get; set; }
  224. /// <summary>
  225. /// type class行政班 teach教学班
  226. /// </summary>
  227. public string type { get; set; }
  228. /// <summary>
  229. /// 教师的醍摩豆id
  230. /// </summary>
  231. public string teacherId { get; set; }
  232. /// <summary>
  233. /// 个人课程,讲座,研讨会,直播开始时间。用通知预报开始时间。
  234. /// </summary>
  235. public long startTime { get; set; }
  236. /// <summary>
  237. /// 开课通知内容,比如临时调整上课地点,或需要准备的资料,开课主讲内容等。
  238. /// </summary>
  239. public string notice { get; set; }
  240. /// <summary>
  241. /// 设计该字段的目的在于可能会出现教师个人课程,使用某一学校名单进行上课,或者教师临时自己开课,使用学校名单。
  242. /// 在个人课程展示这个的时候,只展示教师登录所在的学校,而且要检查当前名单是否与学校一致
  243. /// </summary>
  244. public string school { get; set; }
  245. /// <summary>
  246. /// 助教id集合
  247. /// </summary>
  248. public HashSet<string> assistants { get; set; } = new HashSet<string>();
  249. public int invalidCode { get; set; } = -1;
  250. public string invalidMsg { get; set; }
  251. }
  252. public class ScheduleTime {
  253. /// <summary>
  254. /// 作息的第几节课的id
  255. /// </summary>
  256. public string id { get; set; }
  257. /// <summary>
  258. /// 星期几
  259. /// </summary>
  260. public string week { get; set; }
  261. /// <summary>
  262. /// all全部,single单周,double双周,custom自定义
  263. /// </summary>
  264. public string mode { get; set; }
  265. /// <summary>
  266. /// 自定义序列
  267. /// </summary>
  268. //[1,2,5,8]
  269. public HashSet<int>index { get; set; }= new HashSet<int>();
  270. }
  271. public class IdName
  272. {
  273. public string id { get; set; }
  274. public string name { get; set; }
  275. public string bindId { get; set; }
  276. }
  277. public class CourseCheckImport
  278. {
  279. /// <summary>
  280. /// 开学日期
  281. /// 必填,开学(开课)日期格式,用于计算学年,学期,课表周期,此日期需要大于或等于学校基础信息设置的开学日期: 2023-3-2(年-月-日)
  282. /// </summary>
  283. //public string stime { get; set; }
  284. /// <summary>
  285. /// 课程名称 必填,导入课程的名称,需要与课程列表名称匹配才能导入
  286. /// </summary>
  287. public string name { get; set; }
  288. public int grade { get; set; }
  289. public string courseNo { get; set; }
  290. /// <summary>
  291. /// 名单类型
  292. /// 必填, 行政班=>class 教学班=>teach
  293. /// </summary>
  294. public string type { get; set; }
  295. /// <summary>
  296. /// 行政班编号,教学班名称
  297. /// 必填,
  298. /// 当名单类型为class行政班时:班级入学年-班号=>2022-1,2022-01
  299. /// 当名单类型为teach教学班时:教学班唯一名称=>高一2022物理班
  300. /// </summary>
  301. public string list { get; set; }
  302. public string listName { get; set; }
  303. /// <summary>
  304. /// 教师醍摩豆ID
  305. /// </summary>
  306. public string tmdid { get; set; }
  307. public string tmdName { get; set; }
  308. /// <summary>
  309. /// 教室编号 选题,表示网课或不确定上课教室,编号需要与现有教室列表的编号匹配,才能导入
  310. /// </summary>
  311. public string roomNo { get; set; }
  312. /// <summary>
  313. /// 排课时间段
  314. /// 选填,数据格式:
  315. /// 作息时间段-星期几-排课周期模式-自定义周数
  316. ///
  317. ///作息时间段(如果确定标记排课时间段,则此字段必填):学校上课时间段的第几节课,自然数1,2,3-n
  318. ///星期几(必填):1,2,3,4,5,6,7代表一周星期一到星期天
  319. ///排课周期模式(必填):A(all 全部),S(single单周),D(double)双周,C(custom自定义)
  320. ///自定义周数(选填) :1,2,5,8
  321. /// </summary>
  322. public string schedule { get; set; }
  323. /// <summary>
  324. /// 课程结束时间 ,选填,用于展示课表,如果未展示则自动以下学期开学前的时间为准
  325. /// </summary>
  326. public string etime { get; set; }
  327. /// <summary>
  328. /// 助教
  329. /// </summary>
  330. public string assistants { get; set; }
  331. /// <summary>
  332. /// 助教
  333. /// </summary>
  334. public string assistantNames { get; set; }
  335. /// <summary>
  336. /// -1未验证的,0.验证通过的,1.课程名称无效的,2.醍摩豆ID无效的,3.教学班名称无效的,4.教室编号无效的,5.开学日期无效的,6.课程结束日期无效的,
  337. /// 7.排课时间格式不满足[1-n]-[1|2|3|4|5|6|7]-[A|D|C],8.没有对应的上课时间段,9.上课时间不在星期一至星期日,10.自定义模式下,需要配置对应的上课周,11.自定义模式下,上课周不在1-20周
  338. /// 12.班级入学年-编号不存在,13.导入的班级入学年-编号在系统中重复,请检查行政班设置,14.班级入学年-编号格式错误,15根据开学时间无法获取学期信息,16学期不存在,17,修改的信息必须要有教师或名单中的一项或两项。
  339. /// 18.修改的名单不存在,19修改的教师不存在,20.同一教师,同一班级,同一课程,只能有一条记录,21助教老师不存在
  340. /// </summary>
  341. public int invalidCode { get; set; } = -1;
  342. public string invalidMsg { get; set; }
  343. }
  344. public class CourseTaskInsert
  345. {
  346. /// <summary>
  347. /// 学年
  348. /// </summary>
  349. public int year { get; set; }
  350. /// <summary>
  351. /// 学期id
  352. /// </summary>
  353. public string semesterId { get; set; }
  354. /// <summary>
  355. /// 课程名称 必填,导入课程的名称,需要与课程列表名称匹配才能导入
  356. /// </summary>
  357. public string courseId { get; set; }
  358. /// <summary>
  359. /// 名单类型
  360. /// 必填, 行政班=>class 教学班=>teach
  361. /// </summary>
  362. public string type { get; set; }
  363. /// <summary>
  364. /// 行政班 教学班Id
  365. /// </summary>
  366. public string groupId { get; set; }
  367. /// <summary>
  368. /// 教师醍摩豆ID
  369. /// </summary>
  370. public string teacherId { get; set; }
  371. /// <summary>
  372. /// 教室编号 选题,表示网课或不确定上课教室,编号需要与现有教室列表的编号匹配,才能导入
  373. /// </summary>
  374. public string roomId { get; set; }
  375. /// <summary>
  376. /// 个人课程,讲座,研讨会,直播开始时间。用通知预报开始时间。
  377. /// </summary>
  378. public long startTime { get; set; }
  379. /// <summary>
  380. /// 开课通知内容,比如临时调整上课地点,或需要准备的资料,开课主讲内容等。
  381. /// </summary>
  382. public string notice { get; set; }
  383. /// <summary>
  384. /// -1未验证的,0.验证通过的,1.课程名称无效的,2.醍摩豆ID无效的,3.教学班名称无效的,4.教室编号无效的,5.开学日期无效的,6.课程结束日期无效的,
  385. /// 7.排课时间格式不满足[1-n]-[1|2|3|4|5|6|7]-[A|D|C],8.没有对应的上课时间段,9.上课时间不在星期一至星期日,10.自定义模式下,需要配置对应的上课周,11.自定义模式下,上课周不在1-20周
  386. /// 12.班级入学年-编号不存在,13.导入的班级入学年-编号在系统中重复,请检查行政班设置,14.班级入学年-编号格式错误,15根据开学时间无法获取学期信息,16学期不存在,17,修改的信息必须要有教师或名单中的一项或两项。
  387. /// 18.修改的名单不存在,19修改的教师不存在,20.同一教师,同一班级,同一课程,只能有一条记录,21助教老师不存在,22助教限制10
  388. /// </summary>
  389. public int invalidCode { get; set; } = -1;
  390. //个人的课程 引用其他学校的名单
  391. public string school { get; set; }
  392. public HashSet<string> assistants { get; set; } = new HashSet<string>();
  393. public string invalidMsg { get; set; }
  394. }
  395. public class CourseTaskChanged : CourseTaskInsert
  396. {
  397. /// <summary>
  398. /// 名单类型,变更后的名单类型
  399. /// 行政班=>class 教学班=>teach
  400. /// </summary>
  401. public string typeChanged { get; set; }
  402. /// <summary>
  403. /// 行政班 教学班Id,变更后的名单Id
  404. /// </summary>
  405. public string groupIdChanged { get; set; }
  406. /// <summary>
  407. /// 教师醍摩豆ID,变更后的教师id
  408. /// </summary>
  409. public string teacherIdChanged { get; set; }
  410. }
  411. public class CourseStudentDto
  412. {
  413. public CourseBase courseBase { get; set; }
  414. public List<CourseTask> courseTasks { get; set; } = new List<CourseTask>();
  415. }
  416. public class CourseDto
  417. {
  418. public CourseBase courseBase { get; set; }
  419. public List<CourseTaskDto> courseTasks { get; set; } = new List<CourseTaskDto>();
  420. }
  421. public class CourseTaskDto
  422. {
  423. public CourseTask courseTask { get; set; }
  424. /// <summary>
  425. /// teacher主任课教师,assistant,协同教师
  426. /// </summary>
  427. public string type { get; set; }
  428. }
  429. }