using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace TEAMModelOS.SDK.Models
{
/*
//课程基础信息
"courseBase": {
"id": " uuid1",
"code": "CourseBase-hbcn",
"pk": "CourseBase",
"name": "语文课",
"subject": {
"id": "科目id1",
"name": "高数"
},
"period": {
"id": "学段id1",
"name": "大学"
},
"major": { //专业信息在K12可不设置。
"id": "专业id1",
"name": "软件工程"
},
"scope": "school",
"desc": "软件工程专业-高等数学",
"no": "A101",
"creatorId": "1595321354",
"school": "hbcn",
"color": "red", //用于标记课程表的排课颜色
"grades": [0,1,2], //年级
"status": 1
}
*/
///
/// 课程基础信息
///
public class CourseBase : CosmosEntity
{ ///
/// 课程名称
///
[Required(ErrorMessage = "{0} 必须填写")]
public string name { get; set; }
///
/// 科目
///
public IdName subject { get; set; }
///
/// 学段
///
public IdName period { get; set; }
///
/// 专业 不是必须的。
///
public IdName major { get; set; }
public string scope { get; set; }
///
/// 描述
///
public string desc { get; set; }
///
/// 课程编号
///
public string no { get; set; }
///
/// 创建者的id
///
public string creatorId { get; set; }
///
/// 学校编码
///
public string school { get; set; }
///
/// 颜色,课表标记颜色
///
public string color { get; set; }
///
/// 年级,此处的下标是从0-n开始的。
/// 注:比如高二可能会将高三的课程学完,则该高三的课程的学年级应该是手动处理为高中二年级。不区分学期的目的,也是可能存在提前一学期学完第二学期的课程。
///
public HashSet grades { get; set; } = new HashSet();
///
/// 状态
///
public int status { get; set; } = 1;
}
/*
//课程排课任务
"courseTask": {
//年份+学期,2022-2023第一学期
"id": " 2022-semesterId-courseId",
"code": "CourseTask-hbcn",
"pk": "CourseTask",
"expire": 1577808000000,//默认-1 永不过期,学校的课程则自动根据学期的时间进行设置。
"courseId": "courseIduuid1",//课程id
"year": 2022,//课程所属年份
"semesterId": "学期id",
"weekCount": 20,//课程持续多少周,-1未设定
"timeCount": 10,//课程一周有多少堂课,-1未设定
"schedules": [
{
"roomId": "物理教室id",//
"groupId": "名单id",
"type": "名单类型-class行政班,teach教学班",
"teacherId": "1595321354",
//times可不设置,不设置也不影响HiTeach使用,只是不能展示为课表模式,只能是课程任务列表模式。
"times": [
{
"id": "学校作息时间id",
"week": "MON",//星期几
"mode": "all全部,single单周,double双周,custom自定义",
"index": [
1,
5,
8,
15
]
}
]
}
]
}
*/
///
/// 课程任务
/// 学校课程
/// id 2022-semesterId-courseId
/// code CourseTask-hbcn
/// 个人课程
/// id $"{_courseId}";
/// $"CourseTask-{tmdid}";
///
public class CourseTask : CosmosEntity
{
///
/// 过期时间,-1永不过期, 1577808000000 2020-01-01。 学校的课程则自动根据学期的时间变化。
///
public long expire { get; set; } = -1;
///
/// 课程的id
///
public string courseId { get; set; }
///
/// 课表所属年份
///
public int year { get; set; }
///
/// semesterId 学期id
///
public string semesterId { get; set; }
public List schedules { get; set; } = new List();
///
/// 课程持续多少周,-1未设定
///
public int weekCount { get; set; } = -1;
///
/// 课程一周有多少堂课,-1未设定
///
public int timeCount { get; set; } = -1;
}
public class ScheduleTask
{
///
/// 教室id
///
public string roomId { get; set; }
///
/// 班级名单id: 行政班|教学班
///
public string groupId { get; set; }
///
/// type class行政班 teach教学班
///
public string type { get; set; }
///
/// 教师的醍摩豆id
///
public string teacherId { get; set; }
///
/// 排课时间表
///
public List times { get; set; } = new List();
///
/// 个人课程,讲座,研讨会,直播开始时间。用通知预报开始时间。
///
public long startTime { get; set; }
///
/// 开课通知内容,比如临时调整上课地点,或需要准备的资料,开课主讲内容等。
///
public string notice { get; set; }
///
/// 设计该字段的目的在于可能会出现教师个人课程,使用某一学校名单进行上课,或者教师临时自己开课,使用学校名单。
/// 在个人课程展示这个的时候,只展示教师登录所在的学校,而且要检查当前名单是否与学校一致
///
public string school { get; set; }
///
/// 助教id集合
///
public HashSet assistants { get; set; } = new HashSet();
}
public class ScheduleTaskDto
{
///
/// 教室id
///
public string roomId { get; set; }
///
/// 班级名单id: 行政班|教学班
///
public string groupId { get; set; }
///
/// type class行政班 teach教学班
///
public string type { get; set; }
///
/// 教师的醍摩豆id
///
public string teacherId { get; set; }
///
/// 个人课程,讲座,研讨会,直播开始时间。用通知预报开始时间。
///
public long startTime { get; set; }
///
/// 开课通知内容,比如临时调整上课地点,或需要准备的资料,开课主讲内容等。
///
public string notice { get; set; }
///
/// 设计该字段的目的在于可能会出现教师个人课程,使用某一学校名单进行上课,或者教师临时自己开课,使用学校名单。
/// 在个人课程展示这个的时候,只展示教师登录所在的学校,而且要检查当前名单是否与学校一致
///
public string school { get; set; }
///
/// 助教id集合
///
public HashSet assistants { get; set; } = new HashSet();
public int invalidCode { get; set; } = -1;
public string invalidMsg { get; set; }
}
public class ScheduleTime {
///
/// 作息的第几节课的id
///
public string id { get; set; }
///
/// 星期几
///
public string week { get; set; }
///
/// all全部,single单周,double双周,custom自定义
///
public string mode { get; set; }
///
/// 自定义序列
///
//[1,2,5,8]
public HashSetindex { get; set; }= new HashSet();
}
public class IdName
{
public string id { get; set; }
public string name { get; set; }
}
public class CourseCheckImport
{
///
/// 开学日期
/// 必填,开学(开课)日期格式,用于计算学年,学期,课表周期,此日期需要大于或等于学校基础信息设置的开学日期: 2023-3-2(年-月-日)
///
public string stime { get; set; }
///
/// 课程名称 必填,导入课程的名称,需要与课程列表名称匹配才能导入
///
public string name { get; set; }
///
/// 名单类型
/// 必填, 行政班=>class 教学班=>teach
///
public string type { get; set; }
///
/// 行政班编号,教学班名称
/// 必填,
/// 当名单类型为class行政班时:班级入学年-班号=>2022-1,2022-01
/// 当名单类型为teach教学班时:教学班唯一名称=>高一2022物理班
///
public string list { get; set; }
///
/// 教师醍摩豆ID
///
public string tmdid { get; set; }
///
/// 教室编号 选题,表示网课或不确定上课教室,编号需要与现有教室列表的编号匹配,才能导入
///
public string roomNo { get; set; }
///
/// 排课时间段
/// 选填,数据格式:
/// 作息时间段-星期几-排课周期模式-自定义周数
///
///作息时间段(如果确定标记排课时间段,则此字段必填):学校上课时间段的第几节课,自然数1,2,3-n
///星期几(必填):1,2,3,4,5,6,7代表一周星期一到星期天
///排课周期模式(必填):A(all 全部),S(single单周),D(double)双周,C(custom自定义)
///自定义周数(选填) :1,2,5,8
///
public string schedule { get; set; }
///
/// 课程结束时间 ,选填,用于展示课表,如果未展示则自动以下学期开学前的时间为准
///
public string etime { get; set; }
///
/// 助教
///
public string assistants { get; set; }
///
/// -1未验证的,0.验证通过的,1.课程名称无效的,2.醍摩豆ID无效的,3.教学班名称无效的,4.教室编号无效的,5.开学日期无效的,6.课程结束日期无效的,
/// 7.排课时间格式不满足[1-n]-[1|2|3|4|5|6|7]-[A|D|C],8.没有对应的上课时间段,9.上课时间不在星期一至星期日,10.自定义模式下,需要配置对应的上课周,11.自定义模式下,上课周不在1-20周
/// 12.班级入学年-编号不存在,13.导入的班级入学年-编号在系统中重复,请检查行政班设置,14.班级入学年-编号格式错误,15根据开学时间无法获取学期信息
///
public int invalidCode { get; set; } = -1;
public string invalidMsg { get; set; }
}
public class CourseTaskInsert
{
///
/// 学年
///
public int year { get; set; }
///
/// 学期id
///
public string semesterId { get; set; }
///
/// 课程名称 必填,导入课程的名称,需要与课程列表名称匹配才能导入
///
public string courseId { get; set; }
///
/// 名单类型
/// 必填, 行政班=>class 教学班=>teach
///
public string type { get; set; }
///
/// 行政班 教学班Id
///
public string groupId { get; set; }
///
/// 教师醍摩豆ID
///
public string teacherId { get; set; }
///
/// 教室编号 选题,表示网课或不确定上课教室,编号需要与现有教室列表的编号匹配,才能导入
///
public string roomId { get; set; }
///
/// 个人课程,讲座,研讨会,直播开始时间。用通知预报开始时间。
///
public long startTime { get; set; }
///
/// 开课通知内容,比如临时调整上课地点,或需要准备的资料,开课主讲内容等。
///
public string notice { get; set; }
///
/// -1未验证的,0.验证通过的,1.课程名称无效的,2.醍摩豆ID无效的,3.教学班名称无效的,4.教室编号无效的,5.开学日期无效的,6.课程结束日期无效的,
/// 7.排课时间格式不满足[1-n]-[1|2|3|4|5|6|7]-[A|D|C],8.没有对应的上课时间段,9.上课时间不在星期一至星期日,10.自定义模式下,需要配置对应的上课周,11.自定义模式下,上课周不在1-20周
/// 12.班级入学年-编号不存在,13.导入的班级入学年-编号在系统中重复,请检查行政班设置,14.班级入学年-编号格式错误,15根据开学时间无法获取学期信息,16学期不存在,17,修改的信息必须要有教师或名单中的一项或两项。
/// 18.修改的名单不存在,19修改的教师不存在,20.同一教师,同一班级,同一课程,只能有一条记录,21助教老师不存在
///
public int invalidCode { get; set; } = -1;
//个人的课程 引用其他学校的名单
public string school { get; set; }
public HashSet assistants { get; set; } = new HashSet();
public string invalidMsg { get; set; }
}
public class CourseTaskChanged : CourseTaskInsert
{
///
/// 名单类型,变更后的名单类型
/// 行政班=>class 教学班=>teach
///
public string typeChanged { get; set; }
///
/// 行政班 教学班Id,变更后的名单Id
///
public string groupIdChanged { get; set; }
///
/// 教师醍摩豆ID,变更后的教师id
///
public string teacherIdChanged { get; set; }
}
}