|
@@ -2,7 +2,11 @@ package cn.com.qmth.stmms.admin.report;
|
|
|
|
|
|
import java.io.ByteArrayInputStream;
|
|
import java.io.ByteArrayInputStream;
|
|
import java.io.IOException;
|
|
import java.io.IOException;
|
|
-import java.util.*;
|
|
|
|
|
|
+import java.util.HashMap;
|
|
|
|
+import java.util.HashSet;
|
|
|
|
+import java.util.List;
|
|
|
|
+import java.util.Map;
|
|
|
|
+import java.util.Set;
|
|
|
|
|
|
import javax.servlet.http.HttpServletRequest;
|
|
import javax.servlet.http.HttpServletRequest;
|
|
import javax.servlet.http.HttpServletResponse;
|
|
import javax.servlet.http.HttpServletResponse;
|
|
@@ -25,13 +29,15 @@ import cn.com.qmth.stmms.admin.exam.BaseExamController;
|
|
import cn.com.qmth.stmms.admin.thread.ScoreReportThread;
|
|
import cn.com.qmth.stmms.admin.thread.ScoreReportThread;
|
|
import cn.com.qmth.stmms.biz.exam.model.Exam;
|
|
import cn.com.qmth.stmms.biz.exam.model.Exam;
|
|
import cn.com.qmth.stmms.biz.exam.model.ExamSubject;
|
|
import cn.com.qmth.stmms.biz.exam.model.ExamSubject;
|
|
-import cn.com.qmth.stmms.biz.exam.service.*;
|
|
|
|
|
|
+import cn.com.qmth.stmms.biz.exam.service.ExamService;
|
|
|
|
+import cn.com.qmth.stmms.biz.exam.service.ExamSubjectService;
|
|
import cn.com.qmth.stmms.biz.file.enums.FormatType;
|
|
import cn.com.qmth.stmms.biz.file.enums.FormatType;
|
|
import cn.com.qmth.stmms.biz.file.service.FileService;
|
|
import cn.com.qmth.stmms.biz.file.service.FileService;
|
|
import cn.com.qmth.stmms.biz.lock.LockService;
|
|
import cn.com.qmth.stmms.biz.lock.LockService;
|
|
import cn.com.qmth.stmms.biz.report.model.ReportSubject;
|
|
import cn.com.qmth.stmms.biz.report.model.ReportSubject;
|
|
import cn.com.qmth.stmms.biz.report.query.ReportSubjectQuery;
|
|
import cn.com.qmth.stmms.biz.report.query.ReportSubjectQuery;
|
|
-import cn.com.qmth.stmms.biz.report.service.*;
|
|
|
|
|
|
+import cn.com.qmth.stmms.biz.report.service.ReportService;
|
|
|
|
+import cn.com.qmth.stmms.biz.report.service.ReportSubjectService;
|
|
import cn.com.qmth.stmms.common.annotation.Logging;
|
|
import cn.com.qmth.stmms.common.annotation.Logging;
|
|
import cn.com.qmth.stmms.common.annotation.RoleRequire;
|
|
import cn.com.qmth.stmms.common.annotation.RoleRequire;
|
|
import cn.com.qmth.stmms.common.domain.WebUser;
|
|
import cn.com.qmth.stmms.common.domain.WebUser;
|
|
@@ -61,9 +67,6 @@ public class ReportSubjectRangeController extends BaseExamController {
|
|
@Autowired
|
|
@Autowired
|
|
private ExamSubjectService subjectService;
|
|
private ExamSubjectService subjectService;
|
|
|
|
|
|
- @Autowired
|
|
|
|
- private ExamQuestionService questionService;
|
|
|
|
-
|
|
|
|
@Autowired
|
|
@Autowired
|
|
private LockService lockService;
|
|
private LockService lockService;
|
|
|
|
|
|
@@ -71,12 +74,6 @@ public class ReportSubjectRangeController extends BaseExamController {
|
|
@Autowired
|
|
@Autowired
|
|
private AsyncTaskExecutor taskExecutor;
|
|
private AsyncTaskExecutor taskExecutor;
|
|
|
|
|
|
- @Autowired
|
|
|
|
- private ExamStudentService studentService;
|
|
|
|
-
|
|
|
|
- @Autowired
|
|
|
|
- private MarkGroupService groupService;
|
|
|
|
-
|
|
|
|
@Autowired
|
|
@Autowired
|
|
private ExamService examService;
|
|
private ExamService examService;
|
|
|
|
|
|
@@ -86,24 +83,10 @@ public class ReportSubjectRangeController extends BaseExamController {
|
|
@Autowired
|
|
@Autowired
|
|
private FileService fileService;
|
|
private FileService fileService;
|
|
|
|
|
|
- @Autowired
|
|
|
|
- private ReportSubjectQuestionService reportSubjectQuestionService;
|
|
|
|
-
|
|
|
|
- @Autowired
|
|
|
|
- private ReportSubjectClassService reportSubjectClassService;
|
|
|
|
-
|
|
|
|
- @Autowired
|
|
|
|
- private ReportSubjectTeacherService reportSubjectTeacherService;
|
|
|
|
-
|
|
|
|
- @Autowired
|
|
|
|
- private ReportSubjectCollegeService reportSubjectCollegeService;
|
|
|
|
-
|
|
|
|
- @Autowired
|
|
|
|
- private ReportSubjectGroupService reportSubjectGroupService;
|
|
|
|
-
|
|
|
|
@Logging(menu = "课程分段统计", type = LogType.QUERY)
|
|
@Logging(menu = "课程分段统计", type = LogType.QUERY)
|
|
@RequestMapping
|
|
@RequestMapping
|
|
- public String list(Model model, HttpServletRequest request, ReportSubjectQuery query,RedirectAttributes redirectAttributes) {
|
|
|
|
|
|
+ public String list(Model model, HttpServletRequest request, ReportSubjectQuery query,
|
|
|
|
+ RedirectAttributes redirectAttributes) {
|
|
WebUser wu = RequestUtils.getWebUser(request);
|
|
WebUser wu = RequestUtils.getWebUser(request);
|
|
int examId = getSessionExamId(request);
|
|
int examId = getSessionExamId(request);
|
|
List<ExamSubject> sList = getExamSubject(examId, wu);
|
|
List<ExamSubject> sList = getExamSubject(examId, wu);
|
|
@@ -111,11 +94,11 @@ public class ReportSubjectRangeController extends BaseExamController {
|
|
ReportSubject subject = reportSubjectService.findOne(examId, query.getSubjectCode());
|
|
ReportSubject subject = reportSubjectService.findOne(examId, query.getSubjectCode());
|
|
if (subject != null && subject.getScoreRange() != null && subject.getTotalScore() != null
|
|
if (subject != null && subject.getScoreRange() != null && subject.getTotalScore() != null
|
|
&& subject.getRealityCount() != null) {
|
|
&& subject.getRealityCount() != null) {
|
|
- try{
|
|
|
|
|
|
+ try {
|
|
JSONArray total = getScoreRange(subject.getScoreRange(), subject.getTotalScore(),
|
|
JSONArray total = getScoreRange(subject.getScoreRange(), subject.getTotalScore(),
|
|
subject.getRealityCount(), query.getRange());
|
|
subject.getRealityCount(), query.getRange());
|
|
- model.addAttribute("total",total );
|
|
|
|
- }catch (Exception e){
|
|
|
|
|
|
+ model.addAttribute("total", total);
|
|
|
|
+ } catch (Exception e) {
|
|
e.printStackTrace();
|
|
e.printStackTrace();
|
|
addMessage(redirectAttributes, "分析失败!请检查科目分值是否正确,并重新计算后查看");
|
|
addMessage(redirectAttributes, "分析失败!请检查科目分值是否正确,并重新计算后查看");
|
|
return "redirect:/admin/exam/reportSubjectRange";
|
|
return "redirect:/admin/exam/reportSubjectRange";
|
|
@@ -191,7 +174,7 @@ public class ReportSubjectRangeController extends BaseExamController {
|
|
@RequestMapping("/report")
|
|
@RequestMapping("/report")
|
|
@RoleRequire({ Role.SCHOOL_ADMIN, Role.SUBJECT_HEADER, Role.COLLEGE_ADMIN })
|
|
@RoleRequire({ Role.SCHOOL_ADMIN, Role.SUBJECT_HEADER, Role.COLLEGE_ADMIN })
|
|
public String calculate(HttpServletRequest request, RedirectAttributes redirectAttributes,
|
|
public String calculate(HttpServletRequest request, RedirectAttributes redirectAttributes,
|
|
- @RequestParam String subjectCode,@RequestParam(required = false)Double range) {
|
|
|
|
|
|
+ @RequestParam String subjectCode, @RequestParam(required = false) Double range) {
|
|
int examId = getSessionExamId(request);
|
|
int examId = getSessionExamId(request);
|
|
Set<String> subjectSet = new HashSet<String>();
|
|
Set<String> subjectSet = new HashSet<String>();
|
|
if (!lockService.isLocked(LockType.SCORE_CALCULATE, examId, subjectCode)) {
|
|
if (!lockService.isLocked(LockType.SCORE_CALCULATE, examId, subjectCode)) {
|
|
@@ -203,7 +186,7 @@ public class ReportSubjectRangeController extends BaseExamController {
|
|
ScoreReportThread thread = new ScoreReportThread(map, reportService, false);
|
|
ScoreReportThread thread = new ScoreReportThread(map, reportService, false);
|
|
taskExecutor.submit(thread);
|
|
taskExecutor.submit(thread);
|
|
}
|
|
}
|
|
- return "redirect:/admin/exam/reportSubjectRange?subjectCode=" + subjectCode+"&range="+range;
|
|
|
|
|
|
+ return "redirect:/admin/exam/reportSubjectRange?subjectCode=" + subjectCode + "&range=" + range;
|
|
}
|
|
}
|
|
|
|
|
|
private JSONArray getScoreRange(String scoreRange, double totalScore, Integer totalCount, double range) {
|
|
private JSONArray getScoreRange(String scoreRange, double totalScore, Integer totalCount, double range) {
|