SmartEvaluateStudentController.java 14 KB

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