|
@@ -2,18 +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.HashMap;
|
|
|
|
-import java.util.HashSet;
|
|
|
|
-import java.util.List;
|
|
|
|
-import java.util.Map;
|
|
|
|
-import java.util.Set;
|
|
|
|
|
|
+import java.util.*;
|
|
|
|
|
|
import javax.servlet.http.HttpServletRequest;
|
|
import javax.servlet.http.HttpServletRequest;
|
|
import javax.servlet.http.HttpServletResponse;
|
|
import javax.servlet.http.HttpServletResponse;
|
|
|
|
|
|
-import net.sf.json.JSONArray;
|
|
|
|
-import net.sf.json.JSONObject;
|
|
|
|
-
|
|
|
|
import org.apache.commons.lang.StringUtils;
|
|
import org.apache.commons.lang.StringUtils;
|
|
import org.slf4j.Logger;
|
|
import org.slf4j.Logger;
|
|
import org.slf4j.LoggerFactory;
|
|
import org.slf4j.LoggerFactory;
|
|
@@ -26,27 +19,21 @@ import org.springframework.web.bind.annotation.RequestMapping;
|
|
import org.springframework.web.bind.annotation.RequestParam;
|
|
import org.springframework.web.bind.annotation.RequestParam;
|
|
import org.springframework.web.servlet.mvc.support.RedirectAttributes;
|
|
import org.springframework.web.servlet.mvc.support.RedirectAttributes;
|
|
|
|
|
|
|
|
+import com.qmth.boot.tools.io.ZipWriter;
|
|
|
|
+
|
|
import cn.com.qmth.stmms.admin.exam.BaseExamController;
|
|
import cn.com.qmth.stmms.admin.exam.BaseExamController;
|
|
|
|
+import cn.com.qmth.stmms.admin.thread.ScoreReportObjectiveThread;
|
|
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.ExamQuestionService;
|
|
|
|
-import cn.com.qmth.stmms.biz.exam.service.ExamService;
|
|
|
|
-import cn.com.qmth.stmms.biz.exam.service.ExamStudentService;
|
|
|
|
-import cn.com.qmth.stmms.biz.exam.service.ExamSubjectService;
|
|
|
|
-import cn.com.qmth.stmms.biz.exam.service.MarkGroupService;
|
|
|
|
|
|
+import cn.com.qmth.stmms.biz.exam.service.*;
|
|
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.model.ReportSubjectRange;
|
|
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.ReportService;
|
|
|
|
-import cn.com.qmth.stmms.biz.report.service.ReportSubjectClassService;
|
|
|
|
-import cn.com.qmth.stmms.biz.report.service.ReportSubjectCollegeService;
|
|
|
|
-import cn.com.qmth.stmms.biz.report.service.ReportSubjectGroupService;
|
|
|
|
-import cn.com.qmth.stmms.biz.report.service.ReportSubjectQuestionService;
|
|
|
|
-import cn.com.qmth.stmms.biz.report.service.ReportSubjectService;
|
|
|
|
-import cn.com.qmth.stmms.biz.report.service.ReportSubjectTeacherService;
|
|
|
|
|
|
+import cn.com.qmth.stmms.biz.report.service.*;
|
|
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;
|
|
@@ -55,8 +42,8 @@ import cn.com.qmth.stmms.common.enums.LogType;
|
|
import cn.com.qmth.stmms.common.enums.Role;
|
|
import cn.com.qmth.stmms.common.enums.Role;
|
|
import cn.com.qmth.stmms.common.utils.Encodes;
|
|
import cn.com.qmth.stmms.common.utils.Encodes;
|
|
import cn.com.qmth.stmms.common.utils.RequestUtils;
|
|
import cn.com.qmth.stmms.common.utils.RequestUtils;
|
|
-
|
|
|
|
-import com.qmth.boot.tools.io.ZipWriter;
|
|
|
|
|
|
+import net.sf.json.JSONArray;
|
|
|
|
+import net.sf.json.JSONObject;
|
|
|
|
|
|
/**
|
|
/**
|
|
* 课程分段统计
|
|
* 课程分段统计
|
|
@@ -116,6 +103,9 @@ public class ReportSubjectRangeController extends BaseExamController {
|
|
@Autowired
|
|
@Autowired
|
|
private ReportSubjectGroupService reportSubjectGroupService;
|
|
private ReportSubjectGroupService reportSubjectGroupService;
|
|
|
|
|
|
|
|
+ @Autowired
|
|
|
|
+ private ReportSubjectRangeService reportSubjectRangeService;
|
|
|
|
+
|
|
@Logging(menu = "课程分段统计", type = LogType.QUERY)
|
|
@Logging(menu = "课程分段统计", type = LogType.QUERY)
|
|
@RequestMapping
|
|
@RequestMapping
|
|
public String list(Model model, HttpServletRequest request, ReportSubjectQuery query) {
|
|
public String list(Model model, HttpServletRequest request, ReportSubjectQuery query) {
|
|
@@ -123,15 +113,23 @@ public class ReportSubjectRangeController extends BaseExamController {
|
|
int examId = getSessionExamId(request);
|
|
int examId = getSessionExamId(request);
|
|
List<ExamSubject> sList = getExamSubject(examId, wu);
|
|
List<ExamSubject> sList = getExamSubject(examId, wu);
|
|
if (StringUtils.isNotBlank(query.getSubjectCode()) && query.getRange() != null) {
|
|
if (StringUtils.isNotBlank(query.getSubjectCode()) && query.getRange() != null) {
|
|
- ReportSubject subject = reportSubjectService.findOne(examId, query.getSubjectCode());
|
|
|
|
- if (subject != null && subject.getScoreRange() != null && subject.getTotalScore() != null
|
|
|
|
- && subject.getRealityCount() != null) {
|
|
|
|
- model.addAttribute(
|
|
|
|
- "total",
|
|
|
|
- getScoreRange(subject.getScoreRange(), subject.getTotalScore(), subject.getRealityCount(),
|
|
|
|
- query.getRange()));
|
|
|
|
|
|
+ if (query.getObjective()) {
|
|
|
|
+ ReportSubjectRange subjectRange = reportSubjectRangeService.findOne(examId, query.getSubjectCode());
|
|
|
|
+ if (subjectRange != null && subjectRange.getObjectiveScoreRange() != null
|
|
|
|
+ && subjectRange.getObjectiveScore() != null && subjectRange.getRealityCount() != null) {
|
|
|
|
+ model.addAttribute("total", getScoreRange(subjectRange.getObjectiveScoreRange(),
|
|
|
|
+ subjectRange.getObjectiveScore(), subjectRange.getRealityCount(), query.getRange()));
|
|
|
|
+ }
|
|
|
|
+ } else {
|
|
|
|
+ ReportSubject subject = reportSubjectService.findOne(examId, query.getSubjectCode());
|
|
|
|
+ if (subject != null && subject.getScoreRange() != null && subject.getTotalScore() != null
|
|
|
|
+ && subject.getRealityCount() != null) {
|
|
|
|
+ model.addAttribute("total", getScoreRange(subject.getScoreRange(), subject.getTotalScore(),
|
|
|
|
+ subject.getRealityCount(), query.getRange()));
|
|
|
|
+ }
|
|
}
|
|
}
|
|
- model.addAttribute("locked", lockService.isLocked(LockType.SCORE_CALCULATE, examId, query.getSubjectCode()));
|
|
|
|
|
|
+ model.addAttribute("locked",
|
|
|
|
+ lockService.isLocked(LockType.SCORE_CALCULATE, examId, query.getSubjectCode()));
|
|
}
|
|
}
|
|
model.addAttribute("oldSubjectCode", query.getSubjectCode());
|
|
model.addAttribute("oldSubjectCode", query.getSubjectCode());
|
|
model.addAttribute("subjectList", sList);
|
|
model.addAttribute("subjectList", sList);
|
|
@@ -200,7 +198,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 String subjectCode, @RequestParam boolean objective) {
|
|
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)) {
|
|
@@ -209,8 +207,13 @@ public class ReportSubjectRangeController extends BaseExamController {
|
|
if (!subjectSet.isEmpty()) {
|
|
if (!subjectSet.isEmpty()) {
|
|
Map<Integer, Set<String>> map = new HashMap<Integer, Set<String>>();
|
|
Map<Integer, Set<String>> map = new HashMap<Integer, Set<String>>();
|
|
map.put(examId, subjectSet);
|
|
map.put(examId, subjectSet);
|
|
- ScoreReportThread thread = new ScoreReportThread(map, reportService, false);
|
|
|
|
- taskExecutor.submit(thread);
|
|
|
|
|
|
+ if (objective) {
|
|
|
|
+ ScoreReportThread thread = new ScoreReportThread(map, reportService, false);
|
|
|
|
+ taskExecutor.submit(thread);
|
|
|
|
+ } else {
|
|
|
|
+ ScoreReportObjectiveThread thread = new ScoreReportObjectiveThread(map, reportService, false);
|
|
|
|
+ taskExecutor.submit(thread);
|
|
|
|
+ }
|
|
}
|
|
}
|
|
return "redirect:/admin/exam/reportSubjectRange?subjectCode=" + subjectCode + "&range=" + 10;
|
|
return "redirect:/admin/exam/reportSubjectRange?subjectCode=" + subjectCode + "&range=" + 10;
|
|
}
|
|
}
|