From cc057177b2fb17aee9a173a6adbabdc578fd74c7 Mon Sep 17 00:00:00 2001
From: tangzy <tangzy123456>
Date: Mon, 06 Dec 2021 10:30:44 +0800
Subject: [PATCH] 1.许可

---
 src/main/java/org/springblade/modules/training/service/impl/TrainingRegistrationServiceImpl.java |  158 +++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 149 insertions(+), 9 deletions(-)

diff --git a/src/main/java/org/springblade/modules/training/service/impl/TrainingRegistrationServiceImpl.java b/src/main/java/org/springblade/modules/training/service/impl/TrainingRegistrationServiceImpl.java
index 817f454..ce6644c 100644
--- a/src/main/java/org/springblade/modules/training/service/impl/TrainingRegistrationServiceImpl.java
+++ b/src/main/java/org/springblade/modules/training/service/impl/TrainingRegistrationServiceImpl.java
@@ -6,8 +6,11 @@
 import lombok.AllArgsConstructor;
 import org.springblade.core.mp.support.Condition;
 import org.springblade.core.tool.api.R;
+import org.springblade.modules.FTP.FtpUtil;
 import org.springblade.modules.apply.entity.Apply;
 import org.springblade.modules.apply.excel.ApplyInfoExcel;
+import org.springblade.modules.exam.entity.ExamPaper;
+import org.springblade.modules.exam.service.ExamPaperService;
 import org.springblade.modules.system.entity.User;
 import org.springblade.modules.system.service.IUserDeptService;
 import org.springblade.modules.system.service.IUserService;
@@ -20,6 +23,8 @@
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
+import java.text.DecimalFormat;
+import java.text.SimpleDateFormat;
 import java.util.Date;
 import java.util.List;
 
@@ -35,13 +40,18 @@
 
 	private final IUserDeptService userDeptService;
 
+	private final ExamPaperService examPaperService;
+
 
 	@Override
 	public IPage<TrainingRegistrationVo> selectTrainingRegistrationPage(IPage<TrainingRegistrationVo> page, TrainingRegistrationVo trainingRegistration) {
 		List<TrainingRegistrationVo> trainingRegistrationVos = baseMapper.selectTrainingRegistrationPage(page, trainingRegistration);
-//		trainingRegistrationVos.forEach(trainingRegistrationVo -> {
-//			trainingRegistrationVo.setRemainingTime(LongTimeUtil.getDistanceTime(trainingRegistrationVo.getTrainExamTime().getTime(), System.currentTimeMillis()));
-//		});
+		trainingRegistrationVos.forEach(trainingRegistrationVo -> {
+			//如果考试id 为空,考试尚未提交审核
+			if (null==trainingRegistrationVo.getAuditStatus()){
+				trainingRegistrationVo.setAuditStatus(4);
+			}
+		});
 		return page.setRecords(trainingRegistrationVos);
 	}
 
@@ -71,13 +81,12 @@
 	 */
 	@Override
 	@Transactional(rollbackFor = Exception.class)
-	public void importTrainingRegistration(List<TrainingRegistrationExcel> data, Boolean isCovered) {
+	public void importTrainingRegistration(List<TrainingRegistrationExcel> data, Boolean isCovered,Long examId) {
 		if (data.size()>0){
 			data.forEach(trainingRegistrationExcel -> {
 				TrainingRegistration trainingRegistration = new TrainingRegistration();
-				//通过准考证号
+				//通过身份证号
 				if (null!=trainingRegistrationExcel.getIdCardNo() && trainingRegistrationExcel.getIdCardNo()!=""){
-					trainingRegistration.setCandidateNo(trainingRegistrationExcel.getIdCardNo());
 					User user = userService.getUserInfoByIdCardNo(trainingRegistrationExcel.getIdCardNo());
 					trainingRegistration.setUserId(user.getId().toString());
 
@@ -89,26 +98,155 @@
 						trainingRegistration.setIsExam(1);
 						trainingRegistration.setCancel(1);
 						trainingRegistration.setTrainingTime(new Date());
+						trainingRegistration.setAuditStatus(3);
+						//如果examId不为空
+						if (null!=examId){
+							//查询考试信息
+							ExamPaper examPaper = examPaperService.getById(examId);
+							trainingRegistration.setTrainExamId(examId.toString());
+							//审核通过
+							if (examPaper.getAuditStatus()==1){
+								//生成准考证号
+								trainingRegistration.setCandidateNo(getCandidateNo(trainingRegistration));
+								trainingRegistration.setAuditStatus(1);
+							}
+							//考试审核不通过
+							if (examPaper.getAuditStatus()==2){
+								trainingRegistration.setAuditStatus(2);
+							}
+							//考试待审核
+							if (examPaper.getAuditStatus()==3){
+								trainingRegistration.setAuditStatus(3);
+							}
+						}
 						//新增报名
 						this.save(trainingRegistration);
+
 						//修改保安报名状态
 						user.setIsTrain(1);
 						userService.updateById(user);
+						//数据同步
+						saveTrainingRegistration(trainingRegistration,user);
+
 					}else {
-						if (2 == user.getIsTrain()  || -1==user.getIsTrain() || 3==user.getIsTrain()) {
+						if (user.getIsTrain()!=1) {
 							trainingRegistration.setIsExam(1);
 							trainingRegistration.setCancel(1);
 							trainingRegistration.setTrainingTime(new Date());
+							//如果examId不为空
+							if (null!=examId){
+								//查询考试信息
+								ExamPaper examPaper = examPaperService.getById(examId);
+								trainingRegistration.setTrainExamId(examId.toString());
+								//审核通过
+								if (examPaper.getAuditStatus()==1){
+									//生成准考证号
+									trainingRegistration.setCandidateNo(getCandidateNo(trainingRegistration));
+								}
+							}
 							//新增报名
 							this.save(trainingRegistration);
 							//修改保安报名状态
 							user.setIsTrain(1);
 							userService.updateById(user);
+
+							//数据同步
+							saveTrainingRegistration(trainingRegistration,user);
 						}
 					}
 				}
 			});
 		}
+	}
+
+
+	/**
+	 * 生成准考证号码
+	 * @param trainingRegistration 考试报名信息对象
+	 */
+	private String getCandidateNo(TrainingRegistration trainingRegistration) {
+		//获取考试信息
+		ExamPaper examPaper = examPaperService.getById(trainingRegistration.getTrainExamId());
+		if (null!=examPaper.getStartTime()){
+			String format = new SimpleDateFormat("yyyy-MM-dd").format(examPaper.getStartTime());
+			String year = format.substring(2,4);
+			String quarter  = null;
+			String months = null;
+			int month = Integer.parseInt(format.substring(5,7));
+			int day = Integer.parseInt(format.substring(8,10));
+			String days = null;
+			if (month>0 && month<=3){
+				quarter = "C";
+			}
+			if (month>3 && month<=6){
+				quarter = "X";
+			}
+			if (month>6 && month<=9){
+				quarter = "Q";
+			}
+			if (month>9 && month<=12){
+				quarter = "D";
+			}
+			if (month<=9){
+				months = "0" + month;
+			}
+			if (day<=9){
+				days = "0" + day;
+			}else {
+				days = ""+day;
+			}
+			String type = null;
+			if (examPaper.getExamType()==1){
+				type = "z";
+			}
+			if (examPaper.getExamType()==2){
+				type = "m";
+			}
+			//获取考试名称前缀,去除数字,字母
+			String examName
+				= examPaper.getExamName().replaceAll("\\s*", "").replaceAll("[^(\\u4e00-\\u9fa5)]", "").substring(0,1);
+
+			//前缀 = 年的最后两位  + 月份(两位) + 考试名称(中文拼音)首字母(去除数字,字母) + 考试类型 + 季度拼音首字母大写(春季就是 C)
+//			String result = year
+//							+ months
+//							+ toFirstChar(examName).toUpperCase()
+//							+ examPaper.getExamType()
+//							+ quarter;
+
+			//前缀 = 年的最后两位  + 月份(两位) + 日 (两位) + 考试类型 正式考试  z   模拟考试   m
+			String result = year
+				+ months
+				+ days
+				+ type;
+			//查询是当前前缀已生成的数量
+			int count = this.getCandidateNoCount(result);
+			if (count==0){
+				return result + "0000";
+			}
+			//格式化
+			DecimalFormat decimalFormat = new DecimalFormat("0000");
+			//返回
+			return result + (decimalFormat.format(count++));
+		}
+		return null;
+	}
+
+	/**
+	 * 报名
+	 */
+	private void saveTrainingRegistration(TrainingRegistration trainingRegistration,User user1){
+		String formatStr = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
+		Long id = trainingRegistration.getId();
+		String s = "insert into sys_training_registration(id,training_unit_id,training_time,cancel,user_id,is_exam,audit_status) " +
+			"values(" + "'" + id + "'"
+			+ "," + "'" + trainingRegistration.getTrainingUnitId() +"'"
+			+ "," + "'" + formatStr +"'"
+			+ "," + "'" + trainingRegistration.getCancel() + "'"
+			+ "," + "'" + trainingRegistration.getUserId() + "'"
+			+ "," + "'" + trainingRegistration.getIsExam() + "'"
+			+ "," +"'" + trainingRegistration.getAuditStatus() + "'" + ");" +
+			"update blade_user set is_train = " + user1.getIsTrain() + " " +"where id = " + "'" + user1.getId() + "'";
+		FtpUtil.sqlFileUpload(s);
 	}
 
 
@@ -137,7 +275,9 @@
 	 * @return
 	 */
 	@Override
-	public List<Long> getTrainIds() {
-		return baseMapper.getTrainIds();
+	public List<TrainingRegistration> getTrainIds(TrainingRegistrationVo trainingRegistrationVo) {
+		trainingRegistrationVo.setSerialStart(trainingRegistrationVo.getSerialStart() -1);
+		trainingRegistrationVo.setSerialEnd(trainingRegistrationVo.getSerialEnd() -trainingRegistrationVo.getSerialStart());
+		return baseMapper.getTrainIds(trainingRegistrationVo);
 	}
 }

--
Gitblit v1.9.3