From 9f1351926af2eab8253fb163a02fa75da77f9f64 Mon Sep 17 00:00:00 2001
From: Administrator <admin>
Date: Mon, 20 Dec 2021 10:00:30 +0800
Subject: [PATCH] 成绩修改新增批量审批

---
 src/main/java/org/springblade/modules/exam/service/impl/ScoreAuditRecordsServiceImpl.java |  155 +++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 155 insertions(+), 0 deletions(-)

diff --git a/src/main/java/org/springblade/modules/exam/service/impl/ScoreAuditRecordsServiceImpl.java b/src/main/java/org/springblade/modules/exam/service/impl/ScoreAuditRecordsServiceImpl.java
index bf285b9..ad0d782 100644
--- a/src/main/java/org/springblade/modules/exam/service/impl/ScoreAuditRecordsServiceImpl.java
+++ b/src/main/java/org/springblade/modules/exam/service/impl/ScoreAuditRecordsServiceImpl.java
@@ -218,4 +218,159 @@
 		//返回
 		return true;
 	}
+
+
+	/**
+	 * 批量申请审核
+	 * @param scoreAuditRecords 考试成绩修改申请记录审核
+	 */
+	@Override
+	public boolean batchAudit(ScoreAuditRecordsVO scoreAuditRecords) {
+		List<String> list = Arrays.asList(scoreAuditRecords.getIds().split(","));
+		for (String id : list) {
+			//审核
+			ScoreAuditRecords records = this.getById(id);
+			//如果是审核通过,则修改考试成绩,并改变培训考试状态,用户培训状态
+			if (scoreAuditRecords.getStatus()==2) {
+				//查询考试成绩
+				ExamScore examScore = examScoreService.getById(records.getExamScoreId());
+				//1.修改培训报名考试状态
+				TrainingRegistration trainingRegistration = trainingRegistrationService.getById(examScore.getApplyId());
+				//已考试
+				trainingRegistration.setIsExam(2);
+				//修改
+				trainingRegistrationService.updateById(trainingRegistration);
+
+				//2.修改用户培训考试状态
+				User user = userService.getById(examScore.getUserId());
+				//修改为考试结束状态
+				user.setIsTrain(3);
+
+				//3.修改考试理论成绩
+				examScore.setTheoryGrade(records.getNewScore());
+				//查询用户年龄
+				UserVO userVO = userService.getUserAgeById(Long.parseLong(examScore.getUserId()));
+				//判断实操成绩是否为空
+				if (null == examScore.getLearnGrade()) {
+					//如果为空,之间修改理论成绩和总成绩
+					//总成绩
+					if (userVO.getAge() <= 50) {
+						examScore.setAllGrade(Math.round(examScore.getTheoryGrade()/2));
+					}
+					if (userVO.getAge() > 50) {
+						examScore.setAllGrade(Math.round(examScore.getTheoryGrade()/2));
+					}
+					if (examScore.getTheoryGrade() >= 60) {
+						//实操成绩暂未录入
+						examScore.setQualified(2);
+					}else {
+						//不合格
+						examScore.setQualified(1);
+					}
+					//更新保安数据
+					userService.updateById(user);
+					//更新成绩数据
+					examScoreService.updateById(examScore);
+
+					//内网培训报名,人员,成绩数据同步
+					String s1 =
+						"update exam_score set theory_grade = " + "'" + examScore.getTheoryGrade() + "'" +
+							",all_grade = " + "'" + examScore.getAllGrade() + "'" +
+							",qualified = " + "'" + examScore.getQualified() + "'" +
+							" " + "where id = " + "'" + examScore.getId() + "';"+
+						"update sys_training_registration set is_exam = " + "'" + trainingRegistration.getIsExam() + "'" +
+							" " + "where id = " + "'" + trainingRegistration.getId() + "';"+
+						"update blade_user set is_train = " + "'" +  user.getIsTrain() + "'" +
+							" " + "where id = " + "'" + user.getId() + "'";
+					FtpUtil.sqlFileUpload(s1);
+				} else {
+					//实操成绩不为空
+					if (examScore.getTheoryGrade() >= 60 && examScore.getLearnGrade() >= 60) {
+						//合格
+						examScore.setQualified(0);
+						//设置为未制证的状态
+						user.setUserType(7);
+						//如果已有保安证编号,不更保安证编号信息
+						if (null == user.getSecuritynumber() || user.getSecuritynumber().equals("")) {
+							//去生成保安证编号
+							String pre = SecurityPaperUtil.getSecurityPaper();
+							//查询当前年份已有的保安证编号
+							int count = userService.getSecurityPaperCount(pre);
+							String result = null;
+							if (count == 0) {
+								result = pre + "00001";
+							} else {
+								//格式化
+								DecimalFormat decimalFormat = new DecimalFormat("00000");
+								count++;
+								result = pre + (decimalFormat.format(count));
+							}
+							user.setSecuritynumber(result);
+							//发证日期
+//					user.setPaperTime(new Date());
+							//修改为持证保安
+							user.setHold("1");
+							//更新保安数据
+							userService.updateById(user);
+
+//						String s1 =
+//							"update blade_user set hold = " + "'" + user.getHold() + "'" +
+//								",securitynumber = " + "'" + user.getSecuritynumber() + "'" +
+//								",is_train = " + "'" + user.getIsTrain() + "'" +
+//								" " + "where id = " + "'" + user.getId() + "'";
+//						FtpUtil.sqlFileUpload(s1);
+						}
+					} else {
+						//不合格
+						examScore.setQualified(1);
+					}
+					//总成绩
+					if (userVO.getAge() <= 50) {
+						if (null != examScore.getTheoryGrade()) {
+							examScore.setAllGrade(Math.round((examScore.getTheoryGrade() + examScore.getLearnGrade()) / 2));
+						} else {
+							examScore.setAllGrade(Math.round(examScore.getLearnGrade() / 2));
+						}
+					}
+					if (userVO.getAge() > 50) {
+						if (null != examScore.getTheoryGrade()) {
+							examScore.setAllGrade(Integer.parseInt(String.valueOf(Math.round(examScore.getTheoryGrade() * 0.5)))
+								+ Integer.parseInt(String.valueOf(Math.round(examScore.getLearnGrade() * 0.5))));
+						} else {
+							examScore.setAllGrade(Math.round(examScore.getLearnGrade() / 2));
+						}
+					}
+
+					//更新成绩数据
+					examScoreService.updateById(examScore);
+
+					//内网培训报名,人员,成绩数据同步
+					String s1 =
+						"update exam_score set theory_grade = " + "'" + examScore.getTheoryGrade() + "'" +
+							",all_grade = " + "'" + examScore.getAllGrade() + "'" +
+							",qualified = " + "'" + examScore.getQualified() + "'" +
+							" " + "where id = " + "'" + examScore.getId() + "';"+
+						"update sys_training_registration set is_exam = " + "'" + trainingRegistration.getIsExam() + "'" +
+							" " + "where id = " + "'" + trainingRegistration.getId() + "';"+
+						"update blade_user set hold = " + "'" + user.getHold() + "'" +
+							",securitynumber = " + "'" + user.getSecuritynumber() + "'" +
+							",user_type = " + "'" + user.getUserType() + "'" +
+							",is_train = " + "'" + user.getIsTrain() + "'" +
+							" " + "where id = " + "'" + user.getId() + "'";
+					FtpUtil.sqlFileUpload(s1);
+				}
+			}
+			//审核时间
+			records.setAuditTime(new Date());
+			if (null!=scoreAuditRecords.getAuditDetail() && !scoreAuditRecords.getAuditDetail().equals("")){
+				records.setAuditDetail(scoreAuditRecords.getAuditDetail());
+			}
+			records.setAuditUser(scoreAuditRecords.getAuditUser());
+			records.setStatus(scoreAuditRecords.getStatus());
+			//修改申请记录信息
+			baseMapper.updateById(records);
+		}
+		//返回
+		return true;
+	}
 }

--
Gitblit v1.9.3