|  |  |  | 
|---|
|  |  |  | throw  new BusinessException(ResponseStatus.BAD_REQUEST); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | InsuranceApply model = insuranceApplyMapper.selectById(insuranceApply.getId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(model == null ||!Constants.equalsInteger(model.getIsdeleted(),Constants.ZERO)){ | 
|---|
|  |  |  | throw  new BusinessException(ResponseStatus.DATA_EMPTY); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(Constants.equalsInteger(model.getStatus(),Constants.InsuranceApplyStatus.UPLOAD_INSURANCE.getKey())){ | 
|---|
|  |  |  | throw  new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"对不起,该申请状态已流转,当前不支持该操作~"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Solutions solutions = solutionsMapper.selectById(model.getSolutionId()); | 
|---|
|  |  |  | if(Objects.isNull(solutions)){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"未查询方案信息"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); | 
|---|
|  |  |  | InsuranceApply update = new InsuranceApply(); | 
|---|
|  |  |  | if(Constants.equalsInteger(solutions.getType(),Constants.ZERO)){ | 
|---|
|  |  |  | if(Constants.equalsInteger(model.getStatus(),Constants.InsuranceApplyStatus.UPLOAD_INSURANCE.getKey())){ | 
|---|
|  |  |  | throw  new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"对不起,该申请状态已流转,当前不支持该操作~"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | update.setStatus(Constants.InsuranceApplyStatus.FAIL_RETURN.getKey()); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | if( !(Constants.equalsInteger(model.getStatus(),Constants.InsuranceApplyStatus.WTB_COMPANY_MEMBER_LIST_SIGNATURE.getKey()) | 
|---|
|  |  |  | || Constants.equalsInteger(model.getStatus(),Constants.InsuranceApplyStatus.WTB_COMPANY_APPLY_SIGNATURE.getKey()))){ | 
|---|
|  |  |  | throw  new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"对不起,该申请状态已流转,当前不支持该操作~"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | update.setStatus(Constants.InsuranceApplyStatus.WTB_RETURN.getKey()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | update.setEditDate(new Date()); | 
|---|
|  |  |  | update.setEditor(user.getId()); | 
|---|
|  |  |  | update.setStatus(Constants.InsuranceApplyStatus.FAIL_RETURN.getKey()); | 
|---|
|  |  |  | update.setCheckDate(update.getEditDate()); | 
|---|
|  |  |  | update.setCheckInfo(insuranceApply.getCheckInfo()); | 
|---|
|  |  |  | update.setCheckUserId(user.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | f.setCreator(model.getCreator()); | 
|---|
|  |  |  | f.setObjId(update.getId()); | 
|---|
|  |  |  | f.setCreateDate(update.getEditDate()); | 
|---|
|  |  |  | f.setObjType(Constants.MultiFile.COMPANY_TBD_SIGNED_PDF.getKey()); | 
|---|
|  |  |  | f.setObjType(Constants.MultiFile.BD_SIGNED_PDF.getKey()); | 
|---|
|  |  |  | f.setType(Constants.TWO); | 
|---|
|  |  |  | f.setFileurl(fileurl); | 
|---|
|  |  |  | f.setFileurlFull(fullUrl); | 
|---|
|  |  |  | 
|---|
|  |  |  | ApplyChange update = new ApplyChange(); | 
|---|
|  |  |  | update.setEditDate(new Date()); | 
|---|
|  |  |  | update.setEditor(model.getCreator()); | 
|---|
|  |  |  | update.setStatus(Constants.ApplyChangeStatus.COMPANY_SIGN.getKey()); | 
|---|
|  |  |  | update.setStatus(Constants.ApplyChangeStatus.SIGNATURE.getKey()); | 
|---|
|  |  |  | update.setCheckDate(update.getEditDate()); | 
|---|
|  |  |  | update.setCheckInfo("企业完成签署人员名单"); | 
|---|
|  |  |  | update.setCheckUserId(model.getCreator()); | 
|---|
|  |  |  | 
|---|
|  |  |  | f.setCreator(model.getCreator()); | 
|---|
|  |  |  | f.setObjId(update.getId()); | 
|---|
|  |  |  | f.setCreateDate(update.getEditDate()); | 
|---|
|  |  |  | f.setObjType(Constants.MultiFile.CHANGE_MEMBER_LIST_LATTER.getKey()); | 
|---|
|  |  |  | if(model.getType().equals(Constants.ZERO)){ | 
|---|
|  |  |  | f.setObjType(Constants.MultiFile.CA_APPLY_JIAJIAN_SIGN.getKey()); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | f.setObjType(Constants.MultiFile.CA_APPLY_CHANGEUNIT_SIGN.getKey()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | f.setType(Constants.TWO); | 
|---|
|  |  |  | f.setFileurl(fileurl); | 
|---|
|  |  |  | f.setFileurlFull(fullurl); | 
|---|
|  |  |  | 
|---|
|  |  |  | insuranceApply.setCurrentFee(BigDecimal.ZERO); | 
|---|
|  |  |  | insuranceApply.setCheckUserId(loginUserInfo.getId()); | 
|---|
|  |  |  | insuranceApply.setStatus(insuranceApplyStatus.getKey()); | 
|---|
|  |  |  | insuranceApply.setUnionApplyTbdStatus(Constants.ZERO); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | CountCyclePriceDTO countCyclePriceDTO = new CountCyclePriceDTO(); | 
|---|
|  |  |  | countCyclePriceDTO.setSolutionsId(insuranceApply.getSolutionId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | queryWrapper.eq(InsuranceApply::getIsdeleted,Constants.ZERO); | 
|---|
|  |  |  | queryWrapper.eq(pageWrap.getModel().getBaseSolutionId()!=null,Solutions::getBaseId,pageWrap.getModel().getBaseSolutionId()); | 
|---|
|  |  |  | queryWrapper.in(statusList.size()>0,InsuranceApply::getStatus,statusList); | 
|---|
|  |  |  | queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getSolutionName()),Solutions::getName,pageWrap.getModel().getSolutionName()); | 
|---|
|  |  |  | if(Constants.equalsInteger(pageWrap.getModel().getStatusCollect(),Constants.THREE) ){ | 
|---|
|  |  |  | queryWrapper.eq(InsuranceApply::getStatus,Constants.InsuranceApplyStatus.UPLOAD_INSURANCE.getKey()); | 
|---|
|  |  |  | queryWrapper.lt(InsuranceApply::getEndTime, Utils.Date.getStart(new Date())); | 
|---|
|  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<InsuranceApply> findListByDTO(InsuranceApplyQueryDTO model) { | 
|---|
|  |  |  | LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | MPJLambdaWrapper<InsuranceApply> queryWrapper = new MPJLambdaWrapper<>(); | 
|---|
|  |  |  | queryWrapper.selectAll(InsuranceApply.class); | 
|---|
|  |  |  | queryWrapper.selectAs(Company::getName,InsuranceApply::getCompanyName); | 
|---|
|  |  |  | queryWrapper.selectAs(Solutions::getName,InsuranceApply::getSolutionsName); | 
|---|
|  |  |  | queryWrapper.selectAs(Solutions::getType,InsuranceApply::getSolutionType); | 
|---|
|  |  |  | queryWrapper.select(" ( select count(DISTINCT(ad.MEMBER_ID)) from apply_detail ad  where ad.apply_id = t.id ) as insureNum"); | 
|---|
|  |  |  | queryWrapper.select(" ( select max(ac.APPLY_START_TIME) from apply_change ac  where ac.apply_id = t.id and ac.status = 2 ) as lastChangeDate"); | 
|---|
|  |  |  | queryWrapper.select(" ( select sum(td.fee) from taxes ts inner join tax_detial td on td.TAX_ID = ts.id  where ts.status != 2 and td.INSURANCE_APPLY_ID = t.id ) as taxesMoney "); | 
|---|
|  |  |  | queryWrapper.select(" ( select td.CREATE_DATE from taxes ts inner join tax_detial td on td.TAX_ID = ts.id  where ts.status != 2 and td.INSURANCE_APPLY_ID = t.id order by td.CREATE_DATE desc limit 1 ) as taxesLast "); | 
|---|
|  |  |  | 
|---|
|  |  |  | queryWrapper.leftJoin(Company.class,Company::getId,InsuranceApply::getCompanyId); | 
|---|
|  |  |  | queryWrapper.eq(InsuranceApply::getIsdeleted,Constants.ZERO); | 
|---|
|  |  |  | queryWrapper.eq(model.getUnionApplyId()!=null,InsuranceApply::getUnionApplyId, model.getUnionApplyId()); | 
|---|
|  |  |  | queryWrapper.eq(model.getBaseSolutionId()!=null,Solutions::getBaseId,model.getBaseSolutionId()); | 
|---|
|  |  |  | //企业人员查看本企业数据 | 
|---|
|  |  |  | if(loginUserInfo.getType().equals(Constants.ONE)){ | 
|---|
|  |  |  | queryWrapper.eq(InsuranceApply::getCompanyId, loginUserInfo.getCompanyId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | if(!(insuranceApply.getStatus().equals(Constants.InsuranceApplyStatus.WAIT_SIGNATURE.getKey()) | 
|---|
|  |  |  | ||insuranceApply.getStatus().equals(Constants.InsuranceApplyStatus.SIGNATURE.getKey()) | 
|---|
|  |  |  | ||insuranceApply.getStatus().equals(Constants.InsuranceApplyStatus.FAIL_RETURN.getKey()) | 
|---|
|  |  |  | ||insuranceApply.getStatus().equals(Constants.InsuranceApplyStatus.PLATFORM_CHECK_PASS.getKey()))){ | 
|---|
|  |  |  | ||insuranceApply.getStatus().equals(Constants.InsuranceApplyStatus.PLATFORM_CHECK_PASS.getKey()) | 
|---|
|  |  |  | ||insuranceApply.getStatus().equals(Constants.InsuranceApplyStatus.WTB_RETURN.getKey()) | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | ){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"数据状态无法进行关闭!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //删除其他待办 | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Multifile f = multifileMapper.selectOne(new QueryWrapper<Multifile>().lambda() | 
|---|
|  |  |  | .eq(Multifile::getObjId,model.getId()) | 
|---|
|  |  |  | .eq(Multifile::getObjType,Constants.MultiFile.COMPANY_TBD_SIGNED.getKey()) | 
|---|
|  |  |  | .eq(Multifile::getObjType,Constants.MultiFile.BD_APPLY_PDF.getKey()) | 
|---|
|  |  |  | .eq(Multifile::getIsdeleted,Constants.ZERO).last("limit 1")); | 
|---|
|  |  |  | if(f == null || StringUtils.isBlank(f.getFileurl())){ | 
|---|
|  |  |  | throw  new BusinessException(ResponseStatus.SERVER_ERROR.getCode(),"对不起,获取确认书文件失败,请联系商户确认投保申请书是否正确!"); | 
|---|