PrimaryElective.cs 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. using System;
  2. using System.Collections.Generic;
  3. namespace mxdemo.Mind
  4. {
  5. #region model
  6. public class ElectiveSetting
  7. {
  8. //"selectResult": {
  9. // "params": {},
  10. // "roundId": 8,
  11. // "schoolId": 1,
  12. // "year": 2021,
  13. // "name": "第三次",
  14. // "beginTime": "2022-02-16",
  15. // "endTime": "2022-02-17",
  16. // "groupIds": "1,2,3,10,11,12",
  17. public int currentGeneration; // 当前报名状态
  18. public int preferenceCount; // 选填志愿数量
  19. // "groupList": [
  20. // {
  21. // "params": {},
  22. // "groupId": 1,
  23. // "mask": 448,
  24. // "name": "物化生",
  25. // "rank": 1
  26. // },
  27. // {
  28. // "params": { },
  29. // "groupId": 2,
  30. // "mask": 416,
  31. // "name": "物化政",
  32. // "rank": 2
  33. // },
  34. // {
  35. // "params": { },
  36. // "groupId": 3,
  37. // "mask": 400,
  38. // "name": "物化地",
  39. // "rank": 3
  40. // },
  41. // {
  42. // "params": { },
  43. // "groupId": 10,
  44. // "mask": 56,
  45. // "name": "历政地",
  46. // "rank": 10
  47. // },
  48. // {
  49. // "params": { },
  50. // "groupId": 11,
  51. // "mask": 104,
  52. // "name": "历政生",
  53. // "rank": 11
  54. // },
  55. // {
  56. // "params": { },
  57. // "groupId": 12,
  58. // "mask": 88,
  59. // "name": "历生地",
  60. // "rank": 12
  61. // }
  62. // ],
  63. // "state": "1"
  64. //},
  65. //"allowSelect": false
  66. }
  67. // 评测推荐专业
  68. public class RecommendMajor
  69. {
  70. public string majorCategoryName; // 专业类别
  71. public int majorCategoryCode; // 专业编码
  72. public List<int> matchedGroupIds; // // 匹配哪几个组合?
  73. }
  74. // 学生这里无论什么时间得到的都是最终结果,不需要中间快照,以此区分校长的选科数据。
  75. // 校长的选科数据,初选时与学生相同;补录时也需要这份数据、但也需要初选与补录的差异部分;排名均衡同理
  76. public class ElectiveSelectModel
  77. {
  78. public int groupId; // 组合
  79. public string groupName; // 名称
  80. public int classCount; // 班级数
  81. public int personCount; // 人数设置
  82. // 5.22 注
  83. // 常量 来自发布选科
  84. // 5.7 hht +字段,用来展示报告
  85. public int groupIndicator; // 组合指标 // primary时为设置人数,之后为决策完毕后剩余的设置数
  86. // 5.22 注
  87. // 报名代=Math.max(0, personCount-groupApprovedCount) 决策代=从报名代继承值
  88. // 设置人数-组合录取人数(迭代数)
  89. public int nextGroupIndicator; // 下阶段组合指标
  90. // 5.22 注
  91. // 报名代=0 决策代用来表示超缺=(groupApprovedCount+actualCount[多志愿使用1志愿])-personCount
  92. public bool nextAllowSelect;
  93. public bool nextRecommend;
  94. // 5.26 +nextAllowSelect +nextRecommend
  95. public int rankInIndicator; // 组合指标排名
  96. // 5.22 注
  97. // 未录取学生推荐组合中的排名,其它已录或非推荐组合为0(也就是说最多只会有一个group有值)
  98. // 报名代从决策代继承
  99. public int bestInIndicator; // 未录取组合排名最优人数 // 这是一个解释数据,并没有直接参与计算
  100. public int rankInBest; // bestInIndicator中的排名
  101. // 5.22 注
  102. // bestInIndicator:未录学生的最佳成绩在未录满组合中的分布人数
  103. // rankInBest:未录学生最优的组合中的排名,其它已录取或非成绩最优组合为0(也就是说最多只会有一个group有值)
  104. // 报名代从决策代继承
  105. public int rankInDisenroll; // 全组合指标排名,即所有未录取人员中的排名 // 可能没用
  106. // 5.22 注
  107. // 学生在所有未录取学生中的排名,每个未录组合都会有一个排名(分别按6科成绩排)
  108. // 报名代从决策代继承
  109. public decimal scoreSumAll; // 9门成绩
  110. public decimal scoreSumGroup; // 6门成绩
  111. public bool isRecommend; // 推荐组合
  112. // 5.22 注
  113. // 对应未录学生在决策代匹配算法的推荐组合
  114. // 报名代从决策代继承
  115. public int rankInGroup; // 选科实时排名 常量 来自成绩导入
  116. public int rankInGrade; // 选科全校排名 常量 来自成绩导入
  117. public bool allowSelect; // 是否可以报名 报名代专用
  118. public string disabledReason; // 不可报名时的原因 报名代专用
  119. public bool selected; // 已报名
  120. // 5.13 如果是多志愿,按selectedRank区分一志愿、二志愿、三志愿...
  121. public int selectedRank; // 多志愿时的排序
  122. // 5.20 +用来标识填报时拒填
  123. public bool rejected; // 拒绝填报
  124. public string rejectedReason; // 拒绝原因
  125. // 5.22 注
  126. // selected selectedRank rejected rejectedReason以上报名状态在报名代记录,继承至下一代决策代终止
  127. // 5.13 去除动态列,改为固定字段 +
  128. public int actualCount; // 阶段实际报名人数
  129. // 5.22 注
  130. // 本代报名汇总数据,继承至下一代决策代终止
  131. public bool approved; // 已被正常录取
  132. // 5.22 注
  133. // 学生录取状态,持续继承至所有后代,直至被forceAdjusted更改(非必触发)
  134. public bool forceAdjusted; // 已被调剂录取
  135. // 5.22 注
  136. // 学生强制调剂录取状态,持续继承至所有后代(目前只有forceAdjust代可能会更改此值)
  137. public int groupApprovedCount; // 本组合已被录取人数(迭代值)
  138. // 5.22 注
  139. // 学生正常录取汇总数据,每个决策代累加之前所有决策代的录取数据
  140. public int groupForceAdjustedCount; // 本组合已被强制调剂人数(迭代值)
  141. // 5.22 注
  142. // 学生强制调剂录取汇总数据,每个决策代累加之前所有决策代的录取数据(目前只有forceAdjust代会产生这种数据)
  143. }
  144. public class ElectiveSelectGroupStatistics {
  145. public string name; // stat column name
  146. public ElectiveGeneration.ElectiveGroupGenerationStatistic[] groupDescriptors;
  147. }
  148. ;
  149. public class ElectiveSelectModelWrapper {
  150. public ElectiveSelectModel[] models;
  151. public int generation;
  152. public long studentId;
  153. }
  154. // 自选专业
  155. public class ElectiveOptionalMajor
  156. {
  157. public int collegeId;
  158. public string collegeName;
  159. // 可能还包含院校的一些其它属性
  160. public string majorCategoryCode;
  161. public string majorCategoryName;
  162. public Dictionary<string, string> majors;
  163. public string limitationA; // 选科限制1
  164. public string limitationB; // 选科限制2
  165. public List<int> matchedGroupIds; // 匹配的组合
  166. }
  167. #endregion
  168. // 本期会涉及很多隐藏需求,前端会去back-ui按页面+按功能设置很多按钮功能,后续配置为权限组来操作
  169. // 本期后台输出数据的时候不需要按权限屏蔽数据,全量输出即可,以减少后端开发的工作量
  170. // 因为本期要控制隐藏的内容比功能入口、API入口要更精细的粒度,可能是列表的某几列,可能是某些按钮,如果严格API数据规范可能会增加海量的工作。
  171. public interface IPrimaryElectiveService
  172. {
  173. // 旧接口getStudentSelected,返回内容+preferenceCount,志愿数
  174. ElectiveSetting getStudentSelected();
  175. // 学生获取选科状态数据,得到是每个组合最终状态和结果
  176. // 5.13 返回迭代至generation的多代选科表,如查询补录报名,即返回初录报名/初录结果/补录报名3代的模型集合
  177. ElectiveSelectModelWrapper[] getStudentElectiveModels(long studentId, int generation);
  178. // 学生获取自选专业及匹配情况
  179. List<ElectiveOptionalMajor> getOptionalMajors();
  180. // 初选报名。这里简化原型里的操作,直接提交,如需排序,调sortElectiveSelected接口,并刷新getPrimaryElectivesx
  181. void submitPrimaryElective(ElectiveSelectModel[] models, ElectiveEsign esign);
  182. void esign(ElectiveEsign esign);
  183. // 返回学生测评推荐专业以及匹配情况
  184. List<RecommendMajor> getRecommendMajor();
  185. // /*
  186. // AI分析
  187. // 需要的字段:
  188. // 详细见analysis.json
  189. // */
  190. // List<ElectiveSelectGroupStatistics> getAIAnalysis()
  191. }
  192. }