SmartEvaluateStudentController.java 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  1. package com.template.controller;
  2. import com.alibaba.fastjson.JSONObject;
  3. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  4. import com.template.annotation.DESRespondSecret;
  5. import com.template.annotation.PassToken;
  6. import com.template.api.SmartEvaluateStudentControllerAPI;
  7. import com.template.common.jh.ReqRespResearchProductQuestionnaireItem;
  8. import com.template.common.jh.SectionUtil;
  9. import com.template.common.utils.UUIDUtil;
  10. import com.template.model.evaluate.student.*;
  11. import com.template.model.evaluate.teacher.SimpleScore;
  12. import com.template.model.evaluate.teacher.SmartEvaluateTdetail;
  13. import com.template.model.evaluate.teacher.SmartEvaluateTeacher;
  14. import com.template.model.result.CommonResult;
  15. import com.template.model.result.PageUtils;
  16. import com.template.services.SmartEvaluateSdetailService;
  17. import com.template.services.SmartEvaluateStudentService;
  18. import com.template.services.SmartSubjectManageService;
  19. import com.template.services.SmartSubjectRuleService;
  20. import org.slf4j.Logger;
  21. import org.slf4j.LoggerFactory;
  22. import org.springframework.beans.factory.annotation.Autowired;
  23. import org.springframework.web.bind.annotation.RestController;
  24. import java.util.*;
  25. import java.util.stream.Collectors;
  26. @RestController
  27. //返回参数加密注解
  28. @DESRespondSecret
  29. public class SmartEvaluateStudentController implements SmartEvaluateStudentControllerAPI {
  30. private static Logger logger = LoggerFactory.getLogger(SmartEvaluateStudentController.class);
  31. @Autowired
  32. public SmartSubjectManageService smartSubjectManageService;
  33. @Autowired
  34. public SmartSubjectRuleService smartSubjectRuleService;
  35. @Autowired
  36. public SmartEvaluateStudentService smartEvaluateStudentService;
  37. @Autowired
  38. public SmartEvaluateSdetailService smartEvaluateSdetailService;
  39. @PassToken
  40. public CommonResult operateSmartSubjectManage(JSONObject jsonObject) {
  41. SubjectManageList subjectManageList = null;
  42. try {
  43. subjectManageList = JSONObject.parseObject(jsonObject.toString(), SubjectManageList.class);
  44. } catch (Exception e) {
  45. return CommonResult.errorMsg("参数格式错误");
  46. }
  47. List<SmartSubjectManage> allList = subjectManageList.getSubjectList();
  48. logger.info("===" + allList);
  49. List<String> subjectLists = allList.stream().filter(e -> e.getDeleted() == 0).map(m -> m.getTerm() + m.getName()).collect(Collectors.toList());
  50. Set<String> mainScoreSet = new HashSet<>(subjectLists);
  51. if (subjectLists.size() != mainScoreSet.size()) {
  52. return CommonResult.fail("存在重复学科");
  53. }
  54. QueryWrapper<SmartEvaluateSdetail> queryWrapper1 = new QueryWrapper<>();
  55. queryWrapper1.eq("deleted", 0);
  56. queryWrapper1.eq("term", allList.get(0).getTerm());
  57. List<SmartEvaluateSdetail> smartEvaluateTdetails = smartEvaluateSdetailService.getSmartEvaluateSdetailByKey(queryWrapper1);
  58. if (smartEvaluateTdetails.size() > 0) {
  59. return CommonResult.fail("该学期已有评测数据,不可再更改");
  60. }
  61. for (int i = 0; i < allList.size(); i++) {
  62. SmartSubjectManage smartSubjectManage = allList.get(i);
  63. if (smartSubjectManage.getId() == null) {
  64. smartSubjectManage.setId((int) UUIDUtil.generateID());
  65. }
  66. SmartSubjectManage listc = smartSubjectManageService.getSmartSubjectManageById(smartSubjectManage.getId());
  67. if (listc == null) {
  68. smartSubjectManageService.insertSmartSubjectManage(smartSubjectManage);
  69. } else {
  70. smartSubjectManageService.updateSmartSubjectManage(smartSubjectManage);
  71. }
  72. }
  73. return CommonResult.ok("操作成功");
  74. }
  75. @PassToken
  76. public CommonResult querySubjectManage(String term) {
  77. if (term == null) {
  78. term = smartSubjectManageService.getMaxTerm();
  79. }
  80. QueryWrapper<SmartSubjectManage> queryWrapper1 = new QueryWrapper<>();
  81. queryWrapper1.eq("deleted", 0);
  82. queryWrapper1.eq("term", term);
  83. List<SmartSubjectManage> list = smartSubjectManageService.getSmartSubjectManageByKey(queryWrapper1);
  84. JSONObject jsonObject = new JSONObject();
  85. jsonObject.put("subjectList", list);
  86. return CommonResult.ok(jsonObject);
  87. }
  88. @PassToken
  89. public CommonResult operateSmartSubjectRule(JSONObject jsonObject) {
  90. SmartSubjectRuleOutList smartSubjectRuleOutList = null;
  91. try {
  92. smartSubjectRuleOutList = JSONObject.parseObject(jsonObject.toString(), SmartSubjectRuleOutList.class);
  93. } catch (Exception e) {
  94. return CommonResult.errorMsg("参数格式错误");
  95. }
  96. List<SmartSubjectRuleInList> outList = smartSubjectRuleOutList.getSmartSubjectRuleInLists();
  97. List<SmartSubjectRule> data = new ArrayList<>();
  98. for (int i = 0; i < outList.size(); i++) {
  99. String subjectName = outList.get(i).getSubjectName();
  100. String term = outList.get(i).getTerm();
  101. List<SmartSubjectRule> smartSubjectRules = outList.get(i).getSubjectRuleList();
  102. List<String> ruleList = smartSubjectRules.stream().filter(e -> e.getDeleted() == 0).map(SmartSubjectRule::getLevel).collect(Collectors.toList());
  103. Set<String> ruleSet = new HashSet<>(ruleList);
  104. if (ruleList.size() != ruleSet.size()) {
  105. return CommonResult.fail("存在重复等级");
  106. }
  107. List<String> rangeList = smartSubjectRules.stream().filter(e -> e.getDeleted() == 0).map(SmartSubjectRule::getScoreRange).collect(Collectors.toList());
  108. List<ReqRespResearchProductQuestionnaireItem> all = new ArrayList<>();
  109. for (int j = 0; j < rangeList.size(); j++) {
  110. String[] ls = rangeList.get(j).split("-");
  111. ReqRespResearchProductQuestionnaireItem re = new ReqRespResearchProductQuestionnaireItem(ls[0], ls[1], (byte) 7);
  112. all.add(re);
  113. }
  114. if (SectionUtil.compareSection(all)) {
  115. return CommonResult.fail("存在重复区间");
  116. }
  117. for (int j = 0; j < smartSubjectRules.size(); j++) {
  118. SmartSubjectRule smartSubjectRule = smartSubjectRules.get(j);
  119. if (smartSubjectRule.getId() == null) {
  120. smartSubjectRule.setId((int) UUIDUtil.generateID());
  121. }
  122. smartSubjectRule.setSubjectName(subjectName);
  123. smartSubjectRule.setTerm(term);
  124. data.add(smartSubjectRule);
  125. }
  126. }
  127. for (int i = 0; i < data.size(); i++) {
  128. SmartSubjectRule smartSubjectRule = data.get(i);
  129. SmartSubjectRule rule = smartSubjectRuleService.getSmartSubjectRuleById(smartSubjectRule.getId());
  130. if (rule == null) {
  131. smartSubjectRuleService.insertSmartSubjectRule(smartSubjectRule);
  132. } else {
  133. smartSubjectRuleService.updateSmartSubjectRule(smartSubjectRule);
  134. }
  135. }
  136. return CommonResult.ok("操作成功");
  137. }
  138. @PassToken
  139. public CommonResult querySubjectRule(String term) {
  140. if (term == null) {
  141. term = smartSubjectManageService.getMaxTerm();
  142. }
  143. QueryWrapper<SmartSubjectManage> queryWrapper1 = new QueryWrapper<>();
  144. queryWrapper1.eq("deleted", 0);
  145. queryWrapper1.eq("term", term);
  146. queryWrapper1.eq("shows", 1);
  147. List<SmartSubjectManage> list = smartSubjectManageService.getSmartSubjectManageByKey(queryWrapper1);
  148. JSONObject jsonObject1 = new JSONObject();
  149. List<JSONObject> lj = new ArrayList<>();
  150. for (int i = 0; i < list.size(); i++) {
  151. QueryWrapper<SmartSubjectRule> queryWrapper2 = new QueryWrapper<>();
  152. queryWrapper2.eq("deleted", 0);
  153. queryWrapper2.eq("term", term);
  154. queryWrapper2.eq("subject_name", list.get(i).getName());
  155. List<SmartSubjectRule> list2 = smartSubjectRuleService.getSmartSubjectRuleByKey(queryWrapper2);
  156. JSONObject jsonObject2 = new JSONObject();
  157. jsonObject2.put("subjectName", list.get(i).getName());
  158. jsonObject2.put("term", term);
  159. jsonObject2.put("subjectRuleList", list2);
  160. lj.add(jsonObject2);
  161. jsonObject1.put("smartSubjectRuleInLists", lj);
  162. }
  163. return CommonResult.ok(jsonObject1);
  164. }
  165. @PassToken
  166. public CommonResult queryEvaluateStudent(SmartEvaluateStudent smartEvaluateStudent, Integer currentPage, Integer pageCount) {
  167. QueryWrapper<SmartEvaluateStudent> queryWrapper1 = new QueryWrapper<>();
  168. queryWrapper1.eq("deleted", 0);
  169. if (smartEvaluateStudent.getName() != null && !smartEvaluateStudent.getName().trim().equals("")) {
  170. queryWrapper1.and(qw -> qw.like("name", smartEvaluateStudent.getName()).or().like("card_no", smartEvaluateStudent.getName()));
  171. }
  172. if (smartEvaluateStudent.getTerm() != null && !smartEvaluateStudent.getTerm().trim().equals("")) {
  173. queryWrapper1.like("term", smartEvaluateStudent.getTerm());
  174. }
  175. if (smartEvaluateStudent.getGradeName() != null && !smartEvaluateStudent.getGradeName().trim().equals("")) {
  176. queryWrapper1.eq("grade_name", smartEvaluateStudent.getGradeName());
  177. }
  178. if (smartEvaluateStudent.getClassName() != null && !smartEvaluateStudent.getClassName().trim().equals("")) {
  179. queryWrapper1.eq("class_name", smartEvaluateStudent.getClassName());
  180. }
  181. if (smartEvaluateStudent.getScoreLevel() != null && !smartEvaluateStudent.getScoreLevel().trim().equals("")) {
  182. queryWrapper1.eq("score_level", smartEvaluateStudent.getClassName());
  183. }
  184. queryWrapper1.orderByDesc("id");
  185. PageUtils<SmartEvaluateStudent> list = smartEvaluateStudentService.queryPageSmartEvaluateStudent(currentPage, pageCount, queryWrapper1);
  186. return CommonResult.ok(list);
  187. }
  188. @PassToken
  189. public CommonResult evaluateScore(JSONObject jsonObject) {
  190. SmartEvaluateSdetailList smartEvaluateSdetailList = null;
  191. try {
  192. smartEvaluateSdetailList = JSONObject.parseObject(jsonObject.toString(), SmartEvaluateSdetailList.class);
  193. } catch (Exception e) {
  194. return CommonResult.errorMsg("参数格式错误");
  195. }
  196. Integer id = smartEvaluateSdetailList.getId();
  197. List<SmartEvaluateSdetail> scoreList = smartEvaluateSdetailList.getScoreList();
  198. SmartEvaluateStudent student = smartEvaluateStudentService.getSmartEvaluateStudentById(id);
  199. double total = 0;
  200. for (int i = 0; i < scoreList.size(); i++) {
  201. SmartEvaluateSdetail smartEvaluateSdetail = scoreList.get(i);
  202. if (smartEvaluateSdetail.getId() == null) {
  203. smartEvaluateSdetail.setId((int) UUIDUtil.generateID());
  204. }
  205. if (smartEvaluateSdetail.getDeleted() == 0) {
  206. total += smartEvaluateSdetail.getScoreNum();
  207. }
  208. smartEvaluateSdetail.setTerm(student.getTerm());
  209. smartEvaluateSdetail.setCardNo(student.getCardNo());
  210. QueryWrapper<SmartSubjectRule> queryWrapper1 = new QueryWrapper<>();
  211. queryWrapper1.eq("deleted", 0);
  212. queryWrapper1.eq("subject_name", smartEvaluateSdetail.getSubjectName());
  213. List<SmartSubjectRule> rule = smartSubjectRuleService.getSmartSubjectRuleByKey(queryWrapper1);
  214. String scoreLevel = "";
  215. for (int j = 0; j < rule.size(); j++) {
  216. String[] range = rule.get(j).getScoreRange().split("-");
  217. double min = Double.parseDouble(range[0]);
  218. double max = Double.parseDouble(range[1]);
  219. if (smartEvaluateSdetail.getScoreNum() >= min && smartEvaluateSdetail.getScoreNum() <= max) {
  220. scoreLevel = rule.get(j).getLevel();
  221. break;
  222. }
  223. }
  224. smartEvaluateSdetail.setScoreLevel(scoreLevel);
  225. SmartEvaluateSdetail listc = smartEvaluateSdetailService.getSmartEvaluateSdetailById(smartEvaluateSdetail.getId());
  226. if (listc == null) {
  227. smartEvaluateSdetailService.insertSmartEvaluateSdetail(smartEvaluateSdetail);
  228. } else {
  229. smartEvaluateSdetailService.updateSmartEvaluateSdetail(smartEvaluateSdetail);
  230. }
  231. }
  232. student.setScoreComment(smartEvaluateSdetailList.getScoreComment());
  233. student.setScoreNum(total / scoreList.size());
  234. String scoreLevel = "";
  235. QueryWrapper<SmartSubjectRule> queryWrapper2 = new QueryWrapper<>();
  236. queryWrapper2.eq("deleted", 0);
  237. queryWrapper2.eq("subject_name", "平均成绩");
  238. List<SmartSubjectRule> rule = smartSubjectRuleService.getSmartSubjectRuleByKey(queryWrapper2);
  239. for (int i = 0; i < rule.size(); i++) {
  240. String[] range = rule.get(i).getScoreRange().split("-");
  241. double min = Double.parseDouble(range[0]);
  242. double max = Double.parseDouble(range[1]);
  243. if (student.getScoreNum() >= min && student.getScoreNum() <= max) {
  244. scoreLevel = rule.get(i).getLevel();
  245. break;
  246. }
  247. }
  248. student.setScoreLevel(scoreLevel);
  249. smartEvaluateStudentService.updateSmartEvaluateStudent(student);
  250. return CommonResult.ok();
  251. }
  252. @PassToken
  253. public CommonResult queryDetailScore(Integer id) {
  254. if (id == null) {
  255. return CommonResult.fail("请传入id");
  256. }
  257. SmartEvaluateStudent smartEvaluateStudent = smartEvaluateStudentService.getSmartEvaluateStudentById(id);
  258. if (smartEvaluateStudent == null) {
  259. return CommonResult.fail("未查询到相关信息");
  260. }
  261. QueryWrapper<SmartEvaluateSdetail> queryWrapper1 = new QueryWrapper<>();
  262. queryWrapper1.eq("deleted", 0);
  263. queryWrapper1.eq("term", smartEvaluateStudent.getTerm());
  264. queryWrapper1.eq("card_no", smartEvaluateStudent.getCardNo());
  265. List<SmartEvaluateSdetail> list = smartEvaluateSdetailService.getSmartEvaluateSdetailByKey(queryWrapper1);
  266. JSONObject jsonObject = new JSONObject();
  267. jsonObject.put("id", smartEvaluateStudent.getId());
  268. jsonObject.put("scoreComment", smartEvaluateStudent.getScoreComment());
  269. jsonObject.put("scoreList", list);
  270. return CommonResult.ok(jsonObject);
  271. }
  272. }