智慧保安后台管理-外网项目备份
Administrator
2021-08-23 bf93d530532a5910dae6676d23e13aed607baef9
src/main/java/org/springblade/modules/apply/service/impl/ApplyServiceImpl.java
@@ -1,6 +1,7 @@
package org.springblade.modules.apply.service.impl;
import com.alibaba.fastjson.JSON;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import lombok.AllArgsConstructor;
@@ -12,6 +13,8 @@
import org.springblade.common.utils.arg;
import org.springblade.core.mp.support.Condition;
import org.springblade.core.tool.api.R;
import org.springblade.modules.FTP.FtpUtil;
import org.springblade.modules.FTP.OutJson;
import org.springblade.modules.apply.entity.Apply;
import org.springblade.modules.apply.excel.ApplyExcel;
import org.springblade.modules.apply.excel.ApplyInfoExcel;
@@ -20,15 +23,24 @@
import org.springblade.modules.apply.vo.ApplyPaPerVO;
import org.springblade.modules.apply.vo.ApplyVO;
import org.springblade.modules.exam.entity.ExamPaper;
import org.springblade.modules.exam.entity.ExamScore;
import org.springblade.modules.exam.service.ExamPaperService;
import org.springblade.modules.exam.service.ExamScoreService;
import org.springblade.modules.system.entity.User;
import org.springblade.modules.system.service.IUserService;
import org.springblade.modules.training.entity.TrainingRegistration;
import org.springblade.modules.training.service.TrainingRegistrationService;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.*;
import static org.springblade.common.constant.FtpConstant.*;
/**
 * 考试报名服务实现类
@@ -42,6 +54,8 @@
   private final ExamPaperService examPaperService;
   private final IUserService userService;
   private final TrainingRegistrationService trainingRegistrationService;
   /**
    * 自定义分页数据
@@ -110,8 +124,16 @@
               //修改保安报名状态
               user1.setIsApply(1);
               userService.updateById(user1);
               String formatStr = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
               Long id = apply1.getId();
               String s = "insert into sys_apply(id,user_id,apply_time,apply_status,is_exam) " +
                  "values(" + "'" + id + "'" + "," + "'" + apply1.getUserId() + "'" + "," + "'" + formatStr +
                  "'" + "," + "'" + apply1.getApplyStatus() + "'" + "," +"'" + apply1.getIsExam() + "'" + ");" +
                  "update blade_user set is_apply = " + "'" + user1.getIsApply() + "'" +"where id = " + "'" + user1.getId() + "'";
               FtpUtil.sqlFileUpload(s);
            }else {
               if (user1.getIsApply()==2) {
               if (user1.getIsApply()!=1) {
                  Apply apply1 = new Apply();
                  apply1.setApplyStatus(2);
                  //默认为未考试状态
@@ -122,6 +144,15 @@
                  //修改保安报名状态
                  user1.setIsApply(1);
                  userService.updateById(user1);
                  //内网数据同步
                  String formatStr = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
                  Long id = apply1.getId();
                  String s = "insert into sys_apply(id,user_id,apply_time,apply_status,is_exam) " +
                     "values(" + "'" + id + "'" + "," + "'" + apply1.getUserId() + "'" + "," + "'" + formatStr +
                     "'" + "," + "'" + apply1.getApplyStatus() + "'" + "," +"'" + apply1.getIsExam() + "'" + ");" +
                     "update blade_user set is_apply = " + "'" + user1.getIsApply() + "'" +"where id = " + "'" + user1.getId() + "'";
                  FtpUtil.sqlFileUpload(s);
               }
            }
         }
@@ -288,25 +319,22 @@
      //正式考试
      if (apply.getApplyExamType()==1){
         ApplyPaPerVO applyPaPerVO = baseMapper.getApplyInfo(apply);
         String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[0];
         String startTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[1];
         String endTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getEndTime()).split(" ")[1];
         applyPaPerVO.setStringTime(time+" "+startTime.substring(0,startTime.length()-3) +"-"+ endTime.substring(0,endTime.length()-3));
//         String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[0];
//         String startTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[1];
//         String endTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getEndTime()).split(" ")[1];
         applyPaPerVO.setStringTime(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()));
         return applyPaPerVO;
      }
      //模拟考试
      if (apply.getApplyExamType()==2){
         ApplyPaPerVO applyPaPerVO = baseMapper.getTrainApplyInfo(apply);
         String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[0];
         String startTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[1];
         String endTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getEndTime()).split(" ")[1];
         applyPaPerVO.setStringTime(time+" "+startTime.substring(0,startTime.length()-3) +"-"+ endTime.substring(0,endTime.length()-3));
//         String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[0];
//         String startTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[1];
//         String endTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getEndTime()).split(" ")[1];
         applyPaPerVO.setStringTime(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()));
         return applyPaPerVO;
      }
      return null;
   }
@@ -361,13 +389,82 @@
      //查询考试信息
      ExamPaper paper = examPaperService.getById(apply.getExamId());
      map.put("examName",paper.getExamName());
      //查询已报名的总人数
      int num = baseMapper.getApplyDeatailNum(paper.getId());
      map.put("num",num);
      //查询已报名的的人信息集合
      List<ApplyVO> applyVOList = baseMapper.getApplyDetailList(paper.getId());
      map.put("applyList",applyVOList);
      int num = 0;
      if (paper.getExamType()==1){
         //查询已报名的总人数
         num = baseMapper.getApplyDeatailNum(paper.getId());
         map.put("num",num);
         //查询已报名的的人信息集合
         List<ApplyVO> applyVOList = baseMapper.getApplyDetailList(paper.getId());
         map.put("applyList",applyVOList);
      }
      //模拟考试
      if (paper.getExamType()==2){
         //查询已报名的总人数
         num = baseMapper.getTrainDeatailNum(paper.getId());
         map.put("num",num);
         //查询已报名的的人信息集合
         List<ApplyVO> applyVOList = baseMapper.getTrainDetailList(paper.getId());
         map.put("applyList",applyVOList);
      }
      //返回数据
      return map;
   }
   /**
    * 查询保安员个人报名信息
    * @param apply 报名信息,包含userId
    * @return
    */
   @Override
   public ApplyVO getSecurityApplyDetail(ApplyVO apply) {
      return baseMapper.getSecurityApplyDetail(apply);
   }
   /**
    * 修改考试状态
    * @param apply 报名信息,包含userId,applyid
    * @return
    */
   @Override
   public void updateApplyStatus(ApplyVO apply) {
      //正式考
      if (apply.getExamType()==1){
         Apply apply1 = new Apply();
         apply1.setId(apply.getId());
         //考试中
         apply1.setIsExam(3);
         baseMapper.updateById(apply1);
         String s1 =
            "update sys_apply set is_exam = " + apply1.getIsExam() + " " +"where id = " + "'" + apply1.getId() + "'";
         FtpUtil.sqlFileUpload(s1);
      }
      //模拟考
      if (apply.getExamType()==2){
         TrainingRegistration trainingRegistration = new TrainingRegistration();
         trainingRegistration.setId(apply.getId());
         //考试中
         trainingRegistration.setIsExam(3);
         trainingRegistrationService.updateById(trainingRegistration);
         String s1 =
            "update sys_training_registration set is_exam = " + trainingRegistration.getIsExam() + " " +"where id = " + "'" + trainingRegistration.getId() + "'";
         FtpUtil.sqlFileUpload(s1);
      }
   }
   /**
    * 查询报名信息,取最新的一条(即当前userId,)applyId最大的一条记录
    * @param userId
    * @return
    */
   @Override
   public Apply getMaxApplyIdByUserIdInfo(Long userId) {
      return baseMapper.getMaxApplyIdByUserIdInfo(userId);
   }
}