From a9ca0823ab8f33ca85abebcf6ec4a8da235adb49 Mon Sep 17 00:00:00 2001 From: jiangping <jp@doumee.com> Date: 星期二, 30 一月 2024 14:36:49 +0800 Subject: [PATCH] 开发业务接口 --- server/service/src/main/java/com/doumee/service/business/impl/ApplyChangeServiceImpl.java | 524 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 510 insertions(+), 14 deletions(-) diff --git a/server/service/src/main/java/com/doumee/service/business/impl/ApplyChangeServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/ApplyChangeServiceImpl.java index 4651ecc..ad61a06 100644 --- a/server/service/src/main/java/com/doumee/service/business/impl/ApplyChangeServiceImpl.java +++ b/server/service/src/main/java/com/doumee/service/business/impl/ApplyChangeServiceImpl.java @@ -1,6 +1,8 @@ package com.doumee.service.business.impl; import com.alibaba.fastjson.JSONObject; +import com.doumee.biz.system.SystemDictDataBiz; +import com.doumee.core.annotation.excel.ExcelExporter; import com.doumee.core.constants.ResponseStatus; import com.doumee.core.exception.BusinessException; import com.doumee.core.model.LoginUserInfo; @@ -21,6 +23,7 @@ import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.doumee.service.business.third.SignService; import com.github.xiaoymin.knife4j.core.util.CollectionUtils; import com.github.yulichang.wrapper.MPJLambdaWrapper; import org.apache.commons.lang3.StringUtils; @@ -51,8 +54,15 @@ private InsuranceApplyMapper insuranceApplyMapper; @Autowired + private CompanySolutionMapper companySolutionMapper; + + @Autowired private ApplyChangeJoinMapper applyChangeJoinMapper; + @Autowired + private SystemDictDataBiz systemDictDataBiz; + @Autowired + private SignService signService; @Autowired private ApplyChagneDetailJoinMapper applyChagneDetailJoinMapper; @@ -62,6 +72,8 @@ @Autowired private MemberMapper memberMapper; + @Autowired + private MultifileMapper multifileMapper; @Autowired private DuSolutionMapper duSolutionMapper; @Autowired @@ -74,8 +86,8 @@ private SolutionsMapper solutionsMapper; /** - * 骞冲彴閫�鍥炵敵璇� - * @param insuranceApply + * 骞冲彴閫�鍥炴姇淇� + * @param param * @return */ @Override @@ -89,7 +101,9 @@ if(model == null ||!Constants.equalsInteger(model.getIsdeleted(),Constants.ZERO)){ throw new BusinessException(ResponseStatus.DATA_EMPTY); } - if(Constants.equalsInteger(model.getStatus(),Constants.ApplyChangeStatus.UPLOAD.getKey())){ + if(Constants.equalsInteger(model.getStatus(),Constants.ApplyChangeStatus.UPLOAD.getKey()) + ||Constants.equalsInteger(model.getStatus(),Constants.ApplyChangeStatus.APPROVE.getKey())){ + //宸叉彁浜ゅ拰宸插畬鎴愮姸鎬佷笉鏀寔瀹℃牳涓嶉�氳繃 throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧凤紝璇ョ敵璇风姸鎬佸凡娴佽浆锛屽綋鍓嶄笉鏀寔璇ユ搷浣渵"); } LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); @@ -103,12 +117,319 @@ update.setId(model.getId()); applyChangeMapper.updateById(update); - Constants.ApplyLogType applyLogType = Constants.ApplyLogType.PLATFORM_RETURN; + Constants.ApplyLogType applyLogType = Constants.ApplyLogType.CA_PLATFORM_CHECK_PASS_NO; String info =applyLogType.getInfo(); info = info.replace("${param}", update.getCheckInfo()); ApplyLog log = new ApplyLog(update,applyLogType.getName(),info,update.getId(),applyLogType.getKey(), JSONObject.toJSONString(model), JSONObject.toJSONString(update)); applyLogMapper.insert(log); return 1; + + } + + @Override + @Transactional(rollbackFor = {Exception.class,BusinessException.class}) + public Integer uploadPidan(ApplyChange param) { + if(param.getId() == null + || param.getValidCode() == null + || param.getApplyStartTime() == null + || param.getPidanFile() == null + ||StringUtils.isBlank( param.getPidanFile().getFileurl()) + ||StringUtils.isBlank( param.getPidanFile() .getName())){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + + ApplyChange model = applyChangeMapper.selectById(param.getId()); + if(model == null ||!Constants.equalsInteger(model.getIsdeleted(),Constants.ZERO)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY); + } + if(!Constants.equalsInteger(model.getStatus(),Constants.ApplyChangeStatus.SIGNATURE.getKey())){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧凤紝璇ョ敵璇风姸鎬佸凡娴佽浆锛屽綋鍓嶄笉鏀寔璇ユ搷浣渵"); + } + + LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); + ApplyChange update = new ApplyChange(); + update.setEditDate(new Date()); + update.setEditor(user.getId()); + update.setStatus(Constants.ApplyChangeStatus.APPROVE.getKey()); + update.setCheckDate(update.getEditDate()); + update.setCheckInfo(param.getCheckInfo()); + update.setCheckUserId(user.getId()); + update.setId(model.getId()); + update.setValidCode(param.getValidCode()); + update.setApplyStartTime(model.getApplyStartTime()); + applyChangeMapper.updateById(update); + + param.getPidanFile().setIsdeleted(Constants.ZERO); + param.getPidanFile().setCreator(user.getId()); + param.getPidanFile().setObjId(update.getId()); + param.getPidanFile().setCreateDate(update.getEditDate()); + param.getPidanFile().setObjType(Constants.MultiFile.CA_PD_PDF.getKey()); + param.getPidanFile().setType(Constants.TWO); + multifileMapper.insert(param.getPidanFile()); + + update.setApplyId(model.getApplyId()); + if(Constants.equalsInteger(model.getType(),Constants.ZERO)){ + //濡傛灉鏄姞鍑忎繚鐢宠 澶勭悊鍔犲噺淇濇槑缁嗘暟鎹� + dealDetailsValidTime(update); + }else{ + //濡傛灉鏄崲鍘傜敵璇� 澶勭悊鏄庣粏鏁版嵁 + dealDetailsDUdata(update); + } + + + Constants.ApplyLogType applyLogType = Constants.ApplyLogType.CA_PLATFORM_APPROVE; + String info = ""; + if(model.getValidTime()!=null && model.getValidTime().getTime()/1000!= param.getApplyStartTime().getTime()/1000){ + info =applyLogType.getInfo(); + info = info.replace("${param1}",DateUtil.getPlusTime2(model.getValidTime())); + info = info.replace("${param2}",DateUtil.getPlusTime2(param.getApplyStartTime())); + } + ApplyLog log = new ApplyLog(update,applyLogType.getName(), info,update.getId(),applyLogType.getKey(),JSONObject.toJSONString(model), JSONObject.toJSONString(update)); + applyLogMapper.insert(log); + + return 1; + + } + @Override + @Transactional(rollbackFor = {Exception.class,BusinessException.class}) + public Integer editPidan(ApplyChange param) { + if(param.getId() == null + || param.getValidCode() == null + || param.getPidanFile() == null + || param.getCheckInfo() == null + ||StringUtils.isBlank( param.getPidanFile().getFileurl()) + ||StringUtils.isBlank( param.getPidanFile() .getName())){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + + ApplyChange model = applyChangeMapper.selectById(param.getId()); + if(model == null ||!Constants.equalsInteger(model.getIsdeleted(),Constants.ZERO)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY); + } + if(!Constants.equalsInteger(model.getStatus(),Constants.ApplyChangeStatus.APPROVE.getKey())){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧凤紝璇ョ敵璇峰綋鍓嶄笉鏀寔璇ユ搷浣渵"); + } + + LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); + ApplyChange update = new ApplyChange(); + update.setEditDate(new Date()); + update.setEditor(user.getId()); + update.setCheckDate(update.getEditDate()); + update.setCheckInfo(param.getCheckInfo()); + update.setCheckUserId(user.getId()); + update.setId(model.getId()); + update.setValidCode(param.getValidCode()); + applyChangeMapper.updateById(update); + //鍒犻櫎鍘熸湁鐨勪繚鍗曚俊鎭� + multifileMapper.delete(new UpdateWrapper<Multifile>().lambda() + .set(Multifile::getIsdeleted,Constants.ZERO) + .eq(Multifile::getIsdeleted,Constants.ZERO) + .eq(Multifile::getObjId,update.getId()) + .eq(Multifile::getObjType,Constants.MultiFile.CA_PD_PDF.getKey()) + ); + param.getPidanFile().setIsdeleted(Constants.ZERO); + param.getPidanFile().setObjId(update.getId()); + param.getPidanFile().setCreator(user.getId()); + param.getPidanFile().setCreateDate(update.getEditDate()); + param.getPidanFile().setObjType(Constants.MultiFile.CA_PD_PDF.getKey()); + param.getPidanFile().setType(Constants.TWO); + multifileMapper.insert(param.getPidanFile()); + + Constants.ApplyLogType applyLogType = Constants.ApplyLogType.CA_PALTFORM_EDIT_PIDAN; + String info = applyLogType.getInfo(); + info = info.replace("${param}",param.getCheckInfo()); + ApplyLog log = new ApplyLog(update,applyLogType.getName(), info,update.getId(),applyLogType.getKey(),JSONObject.toJSONString(model), JSONObject.toJSONString(update)); + applyLogMapper.insert(log); + + return 1; + + } + + /** + * 澶勭悊鍔犲噺淇濇槑缁嗘暟鎹� + * @param update + */ + private void dealDetailsDUdata(ApplyChange update ) { + List<ApplyChagneDetail> detailList = applyChagneDetailJoinMapper.selectJoinList(ApplyChagneDetail.class, + new MPJLambdaWrapper<ApplyChagneDetail>() + .selectAll(ApplyChagneDetail.class) + .selectAs(Solutions::getTimeUnit,ApplyChagneDetail::getSolutionTimeUnit) + .selectAs(Solutions::getPrice,ApplyChagneDetail::getSolutionPrice) + .leftJoin(ApplyChange.class, ApplyChange::getId, ApplyChagneDetail::getApplyChangeId) + .leftJoin(Solutions.class, Solutions::getId, ApplyChange::getSolutionsId) + .eq(ApplyChagneDetail::getApplyChangeId,update.getId()) + .eq(ApplyChagneDetail::getIsdeleted,Constants.ZERO) ); + if(detailList ==null || detailList.size()==0){ + return; + } + for(ApplyChagneDetail detail : detailList){ + //鏌ヨ鍛樺伐鏄湪涓诲崟涓� 鏄惁瀛樺湪鐢熸晥涓殑鏁版嵁 + ApplyDetail oldModel = applyDetailJoinMapper.selectOne(new QueryWrapper<ApplyDetail>().lambda() + .eq(ApplyDetail::getApplyId, update.getApplyId()) + .eq(ApplyDetail::getMemberId, detail.getMemberId()) + .orderByDesc(ApplyDetail::getCreateDate) + .last("limit 1")); + if(oldModel == null ){ + throw new BusinessException(ResponseStatus.SERVER_ERROR.getCode(),"瀵逛笉璧凤紝鐢ㄦ埛銆�"+detail.getMemberName()+"銆戝師淇濆崟淇℃伅鏈夎锛屽綋鍓嶇敵璇蜂笉鏀寔鍑忎繚澶勭悊锛�"); + } + applyDetailJoinMapper.update(null, new UpdateWrapper<ApplyDetail>().lambda() + .set(ApplyDetail::getEditor,update.getEditor()) + .set(ApplyDetail::getWorktypeId,detail.getWorktypeId()) + .set(ApplyDetail::getDuId,detail.getDuId()) + .set(ApplyDetail::getEditDate,update.getEditDate()) + .eq(ApplyDetail::getId,oldModel.getApplyId()) + ); + + } + } + /** + * 澶勭悊鍔犲噺淇濇槑缁嗘暟鎹� + * @param update + */ + private void dealDetailsValidTime(ApplyChange update ) { + List<ApplyChagneDetail> detailList = applyChagneDetailJoinMapper.selectJoinList(ApplyChagneDetail.class, + new MPJLambdaWrapper<ApplyChagneDetail>() + .selectAll(ApplyChagneDetail.class) + .selectAs(Solutions::getTimeUnit,ApplyChagneDetail::getSolutionTimeUnit) + .selectAs(Solutions::getPrice,ApplyChagneDetail::getSolutionPrice) + .leftJoin(ApplyChange.class, ApplyChange::getId, ApplyChagneDetail::getApplyChangeId) + .leftJoin(Solutions.class, Solutions::getId, ApplyChange::getSolutionsId) + .eq(ApplyChagneDetail::getApplyChangeId,update.getId()) + .eq(ApplyChagneDetail::getIsdeleted,Constants.ZERO) ); + if(detailList ==null || detailList.size()==0){ + return; + } + List<ApplyDetail> addList = new ArrayList<>(); + List<Integer> reduceMembers = new ArrayList<>(); + BigDecimal totalFee = new BigDecimal(0); + BigDecimal currentFee = new BigDecimal(0); + + for(ApplyChagneDetail detail : detailList){ + if(Constants.equalsInteger(detail.getType(),Constants.ZERO)){ + //鍔犱繚 + ApplyDetail add = new ApplyDetail(); + add.setApplyId(update.getApplyId()); + add.setValidCode(update.getValidCode()); + add.setFee(detail.getFee()); + add.setIsdeleted(Constants.ZERO); + add.setCreator(update.getEditor()); + add.setCreateDate(update.getEditDate()); + add.setMemberId(detail.getMemberId()); + add.setMemberName(detail.getMemberName()); + add.setWorktypeId(detail.getWorktypeId()); + add.setDuId(detail.getDuId()); + add.setStartTime(update.getApplyStartTime()); + add.setEndTime(detail.getEndTime()); + add.setFee(Constants.countDetailFee(detail.getSolutionTimeUnit(),detail.getSolutionPrice(), add.getStartTime(),add.getEndTime())); + if(DateUtil.daysBetweenDates(add.getStartTime(),new Date() )>=0){ + //濡傛灉宸蹭骇鐢熻垂鐢紝璁$畻宸蹭骇鐢熻垂鐢� + add.setCurrentFee(Constants.countDetailFee(detail.getSolutionTimeUnit(),detail.getSolutionPrice(), add.getStartTime(),new Date())); + } + addList.add(add); + totalFee.add(add.getFee()); + currentFee.add(add.getCurrentFee()); + }else{ + //鍑忎繚鎿嶄綔 + //鏌ヨ鍛樺伐鏄湪涓诲崟涓� 鏄惁瀛樺湪鐢熸晥涓殑鏁版嵁 + ApplyDetail oldModel = applyDetailJoinMapper.selectOne(new QueryWrapper<ApplyDetail>().lambda() + .eq(ApplyDetail::getApplyId, update.getApplyId()) + .eq(ApplyDetail::getMemberId, detail.getMemberId()) + .orderByDesc(ApplyDetail::getCreateDate) + .last("limit 1")); + if(oldModel == null || oldModel.getStartTime()==null || oldModel.getStartTime().getTime() > update.getApplyStartTime().getTime()){ + throw new BusinessException(ResponseStatus.SERVER_ERROR.getCode(),"瀵逛笉璧凤紝鐢ㄦ埛銆�"+detail.getMemberName()+"銆戝師淇濆崟淇℃伅鏈夎锛屽綋鍓嶇敵璇蜂笉鏀寔鍑忎繚澶勭悊锛�"); + } + BigDecimal updateFee = (Constants.countDetailFee(detail.getSolutionTimeUnit(),detail.getSolutionPrice(), oldModel.getStartTime(),update.getApplyStartTime())); + BigDecimal updateCurrentFee = new BigDecimal(0); + if(DateUtil.daysBetweenDates(update.getApplyStartTime(),new Date() )>0){ + //濡傛灉鐢熸晥鏃堕棿 鏄粖澶╀箣鍓嶏紝閫�鍥炲凡浜х敓璐圭敤锛岃绠楀凡浜х敓璐圭敤(鎬昏垂鐢�-宸蹭骇鐢熻垂鐢�) + updateCurrentFee = updateFee.subtract(oldModel.getCurrentFee()); + } + applyDetailJoinMapper.update(null, new UpdateWrapper<ApplyDetail>().lambda() + .setSql(" fee = ifnull(fee,0)+"+updateFee) + .setSql(" current_fee = "+updateFee) + .set(ApplyDetail::getEditor,update.getEditor()) + .set(ApplyDetail::getEditDate,update.getEditDate()) + .eq(ApplyDetail::getId,oldModel.getApplyId()) + ); + totalFee.add(updateFee); + currentFee.add(updateCurrentFee); + + } + } + if(addList!=null && addList.size()>0){ + applyDetailJoinMapper.insertBatchSomeColumn(addList); + } + if(totalFee.compareTo(new BigDecimal(0)) != 0){ + //濡傛灉淇濆崟閲戦鍙戠敓缂栫爜锛屾洿鏂版�讳繚鍗曢噾棰� + insuranceApplyMapper.update(null, new UpdateWrapper<InsuranceApply>().lambda() + .setSql(" fee = ifnull(fee,0)+"+totalFee) + .setSql(" current_fee = ifnull(current_fee,0)+"+currentFee) + .set(InsuranceApply::getEditor,update.getEditor()) + .set(InsuranceApply::getEditDate,update.getEditDate()) + .eq(InsuranceApply::getId,update.getApplyId()) + ); + + } + + } + + /** + * 骞冲彴閫�鍥炴姇淇� + * @param param + * @return + */ + @Override + @Transactional(rollbackFor = {Exception.class,BusinessException.class}) + public Integer dealBackApply(ApplyChange param) { + if(param.getId() == null ||StringUtils.isBlank(param.getCheckInfo())){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + ApplyChange model = applyChangeMapper.selectById(param.getId()); + + if(model == null ||!Constants.equalsInteger(model.getIsdeleted(),Constants.ZERO)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY); + } + + LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); + Constants.ApplyLogType applyLogType = null; + String info = ""; + ApplyChange update = new ApplyChange(); + if(param.getDealBackApply() ==1){ + //濡傛灉鏄┏鍥�,鍙兘鍙┏鍥炲凡绛剧珷鐘舵�佷笅鐨勯��鍥炵敵璇风姸鎬佽繘琛屾搷浣� + if(!Constants.equalsInteger(model.getStatus(),Constants.ApplyChangeStatus.RETURN_APPLY_SIGNATURE.getKey())){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧凤紝璇ョ敵璇风姸鎬佸凡娴佽浆锛屽綋鍓嶄笉鏀寔璇ユ搷浣渵"); + } + applyLogType = Constants.ApplyLogType.CA_PALTFORM_REFUSE_APPLY; + info = applyLogType.getInfo(); + info = info.replace("${param}", param.getCheckInfo()); + update.setStatus(Constants.ApplyChangeStatus.SIGNATURE.getKey()); + }else{ + //濡傛灉鏄悓鎰�,涓ょ鐢宠閫�鍥炵姸鎬侀兘鍙搷浣� + if(!(Constants.equalsInteger(model.getStatus(),Constants.ApplyChangeStatus.RETURN_APPLY_SIGNATURE.getKey()) + ||Constants.equalsInteger(model.getStatus(),Constants.ApplyChangeStatus.RETURN_APPLY_UPLOAD.getKey()))){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧凤紝璇ョ敵璇风姸鎬佸凡娴佽浆锛屽綋鍓嶄笉鏀寔璇ユ搷浣渵"); + } + applyLogType = Constants.ApplyLogType.CA_PALTFORM_REFUSE_APPLY; + if( Constants.equalsInteger(model.getStatus(),Constants.ApplyChangeStatus.RETURN_APPLY_SIGNATURE.getKey())){ + update.setStatus(Constants.ApplyChangeStatus.SIGNATURE.getKey()); + }else if( Constants.equalsInteger(model.getStatus(),Constants.ApplyChangeStatus.RETURN_APPLY_UPLOAD.getKey())){ + update.setStatus(Constants.ApplyChangeStatus.UPLOAD.getKey()); + } + } + update.setEditDate(new Date()); + update.setEditor(user.getId()); + //鍚屾剰閫�鍥烇紝鐩存帴鍥炲埌鏈�鍒濈姸鎬侊紝濡傛灉椹冲洖閫�鍥炵敵璇凤紝鍒欎繚鍗曠姸鎬佸洖鍒板緟涓婁紶淇濋櫓鍗� + update.setCheckDate(update.getEditDate()); + update.setCheckInfo(param.getCheckInfo()); + update.setCheckUserId(user.getId()); + update.setId(model.getId()); + applyChangeMapper.updateById(update); + + ApplyLog log = new ApplyLog(update,applyLogType.getName(),info,update.getId(),applyLogType.getKey(),JSONObject.toJSONString(model), JSONObject.toJSONString(update)); + applyLogMapper.insert(log); + return 1; + } @@ -142,6 +463,15 @@ if(Objects.isNull(solutions)){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌淇濋櫓鏂规"); } + CompanySolution companySolution = companySolutionMapper.selectOne(new QueryWrapper<CompanySolution>().lambda() + .eq(CompanySolution::getCompanyId,loginUserInfo.getCompanyId()) + .eq(CompanySolution::getSolutionBaseId,solutions.getId()) + .eq(CompanySolution::getIsdeleted,Constants.ZERO) + .last(" limit 1 ") + ); + if(Objects.isNull(companySolution)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌浼佷笟鍒嗛厤淇濋櫓鏂规淇℃伅"); + } //鐢宠鏃堕棿蹇呴』澶勪簬淇濆崟鐨勬椂闂磋寖鍥村唴 if (!(DateUtil.compareDate(applyChange.getValidTime(), insuranceApply.getStartTime()) >= Constants.ZERO && DateUtil.compareDate(insuranceApply.getEndTime(), applyChange.getValidTime()) >= Constants.ZERO)) { @@ -174,12 +504,18 @@ //鍔犱繚鏁版嵁 List<ApplyChagneDetail> addDetailList = applyChange.getAddDetailList(); if (CollectionUtils.isNotEmpty(addDetailList)) { + if(companySolution.getCanAdd().equals(Constants.ZERO)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "璇ヤ紒涓氬垎閰嶄繚闄╂柟妗堟棤娉曡繘琛屽姞淇�"); + } this.addChangeDetail(applyChange,addDetailList,duWorktypeList,duSolutionList,insuranceApply,solutions,loginUserInfo); } //鍑忎繚鏁版嵁 List<ApplyChagneDetail> delDetailList = applyChange.getDelDetailList(); if (CollectionUtils.isNotEmpty(delDetailList)) { + if(companySolution.getCanReduce().equals(Constants.ZERO)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "璇ヤ紒涓氬垎閰嶄繚闄╂柟妗堟棤娉曡繘琛屽姞淇�"); + } this.delChangeDetail(applyChange,delDetailList,insuranceApply,solutions,loginUserInfo); } //鎹㈠巶涓氬姟 @@ -239,13 +575,12 @@ List<ApplyDetail> applyDetailList = applyDetailJoinMapper.selectList(new QueryWrapper<ApplyDetail>().lambda() .eq(ApplyDetail::getApplyId, applyChange.getApplyId()) .eq(ApplyDetail::getMemberId, applyChagneDetail.getMemberId()) - .le(ApplyDetail::getStartTime, "now()") - .ge(ApplyDetail::getEndTime, "now()")); + .orderByDesc(ApplyDetail::getCreateDate)); if (applyDetailList.size() > Constants.ONE) { throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "鍑忎繚浜哄憳銆�" + applyChagneDetail.getMemberName() + "銆戜繚鍗曚俊鎭紓甯革紝瀛樺湪澶氭潯鏁版嵁"); } ApplyDetail applyDetail = applyDetailList.get(Constants.ZERO); - if (applyChange.getValidTime().compareTo(DateUtil.StringToDate(applyDetail.getEndTime())) <= 0) { + if (applyChange.getValidTime().compareTo(applyDetail.getEndTime()) <= 0) { throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "鍑忎繚浜哄憳銆�" + applyChagneDetail.getMemberName() + "銆戜繚鍗曚繚闅滄棩鏈熻嚦锛氥��" + applyDetail.getEndTime() + "銆戞棤娉曢�氳繃鏈鐢宠"); } applyChagneDetail.setCreateDate(new Date()); @@ -254,8 +589,8 @@ applyChagneDetail.setApplyChangeId(applyChange.getId()); applyChagneDetail.setType(Constants.ONE); applyChagneDetail.setFee( - Constants.countDetailFee(solutions,DateUtil.stringToDate(applyDetail.getEndTime(),"yyyy-MM-dd HH:mm:ss"),DateUtil.stringToDate(applyDetail.getStartTime(),"yyyy-MM-dd HH:mm:ss")) - .subtract(Constants.countDetailFee(solutions,applyChange.getValidTime(),DateUtil.stringToDate(applyDetail.getStartTime(),"yyyy-MM-dd HH:mm:ss"))) + Constants.countDetailFee(solutions, applyDetail.getEndTime(),applyDetail.getStartTime()) + .subtract(Constants.countDetailFee(solutions,applyChange.getValidTime(), applyDetail.getStartTime())) ); applyChagneDetailJoinMapper.insert(applyChagneDetail); } @@ -365,7 +700,7 @@ throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "鎹㈠巶浜哄憳銆�" + applyChagneDetail.getMemberName() + "銆戜繚鍗曚俊鎭紓甯革紝瀛樺湪澶氭潯鏁版嵁"); } ApplyDetail applyDetail = applyDetailList.get(Constants.ZERO); - if(applyChange.getValidTime().compareTo(DateUtil.StringToDate(applyDetail.getEndTime()))<=0){ + if(applyChange.getValidTime().compareTo( applyDetail.getEndTime())<=0){ throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "鎹㈠巶浜哄憳銆�" + applyChagneDetail.getMemberName() + "銆戜繚鍗曚繚闅滄棩鏈熻嚦锛氥��"+applyDetail.getEndTime()+"銆戞棤娉曢�氳繃鏈鐢宠"); } //楠岃瘉娲鹃仯鍗曚綅淇℃伅 涓庡伐绉嶄俊鎭� 鏄惁瀛樺湪 @@ -533,8 +868,8 @@ throw new BusinessException(ResponseStatus.DATA_ERRO.getCode(),"鏁版嵁宸插垹闄�,鏃犳硶杩涜璇ユ搷浣�"); } Constants.ApplyChangeLogStatus applyChangeLogStatus = Constants.ApplyChangeLogStatus.RETURN_APPLY; - - if(applyChangeOptDTO.getOptType().equals(Constants.ApplyChangeStatus.RETURN_APPLY.getKey())){ + if(applyChangeOptDTO.getOptType().equals(Constants.ApplyChangeStatus.RETURN_APPLY_UPLOAD.getKey()) + ||applyChangeOptDTO.getOptType().equals(Constants.ApplyChangeStatus.RETURN_APPLY_SIGNATURE.getKey())){ //鍙戣捣閫�鍥炵敵璇� if(loginUserInfo.getType().equals(Constants.ONE)){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炰紒涓氱鐢ㄦ埛鏃犳硶杩涜璇ユ搷浣�"); @@ -548,7 +883,9 @@ if(loginUserInfo.getType().equals(Constants.ZERO)){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炲钩鍙扮鐢ㄦ埛鏃犳硶杩涜璇ユ搷浣�"); } - if(!applyChange.getStatus().equals(Constants.ApplyChangeStatus.RETURN_APPLY.getKey())){ + if(!(applyChangeOptDTO.getOptType().equals(Constants.ApplyChangeStatus.RETURN_APPLY_UPLOAD.getKey()) + ||applyChangeOptDTO.getOptType().equals(Constants.ApplyChangeStatus.RETURN_APPLY_SIGNATURE.getKey()) + )){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏁版嵁鐘舵�侀敊璇棤娉曡繘琛岃鎿嶄綔!"); } }else if(applyChangeOptDTO.getOptType().equals(Constants.ApplyChangeStatus.UPLOAD.getKey())){ @@ -557,7 +894,9 @@ if(loginUserInfo.getType().equals(Constants.ZERO)){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炲钩鍙扮鐢ㄦ埛鏃犳硶杩涜璇ユ搷浣�"); } - if(!applyChange.getStatus().equals(Constants.ApplyChangeStatus.RETURN_APPLY.getKey())){ + if(!(applyChangeOptDTO.getOptType().equals(Constants.ApplyChangeStatus.RETURN_APPLY_UPLOAD.getKey()) + ||applyChangeOptDTO.getOptType().equals(Constants.ApplyChangeStatus.RETURN_APPLY_SIGNATURE.getKey()) + )){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏁版嵁鐘舵�侀敊璇棤娉曡繘琛岃鎿嶄綔!"); } }else if(applyChangeOptDTO.getOptType().equals(Constants.ApplyChangeStatus.CLOSE.getKey())){ @@ -596,8 +935,165 @@ ApplyChange applyChange = applyChangeJoinMapper.selectOne(queryWrapper); return applyChange; } + /** + * 瀵煎嚭鎹㈠巶鐢宠琛� + * @param param + * @return + */ + @Override + public ApplyChange exportChangeUnitExcel(ApplyChange param){ + ApplyChange model = findJoinDetail(param); + if(Objects.isNull(model) ||! Constants.equalsInteger(Constants.ZERO,model.getType())){ + throw new BusinessException(ResponseStatus.DATA_EMPTY); + } + + //鏌ヨ鏄庣粏 + List<ApplyChagneDetail> detailList =findJoinChangeDetailList(model); + model.setChangeDetailList(detailList!=null?detailList:new ArrayList<>()); + model.setChangeNum(model.getChangeDetailList().size()); + return model; + } + /** + * 瀵煎嚭鎹㈠巶鐢宠琛� + * @param param + * @return + */ + @Override + public String getSignLinkJiajiabao(ApplyChange param){ + ApplyChange model = exportJiajianBaoExcel(param); + return getOnlineSignLink(model); + } + /** + * 瀵煎嚭鎹㈠巶鐢宠琛� + * @param param + * @return + */ + @Override + public String getSignLinkChangeUnit(ApplyChange param){ + ApplyChange model = exportChangeUnitExcel(param); + return getOnlineSignLink(model); + } + + private String getOnlineSignLink(ApplyChange model) { + if(Objects.isNull(model) ||! Constants.equalsInteger(Constants.ZERO,model.getType())){ + throw new BusinessException(ResponseStatus.DATA_EMPTY); + } + if(!Constants.equalsInteger(Constants.ZERO,model.getStatus())){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"瀵逛笉璧凤紝璇ョ敵璇风姸鎬佸凡娴佽浆锛屽綋鍓嶄笉鏀寔绛剧珷鎿嶄綔锛�"); + } + LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); + Company company = user.getCompany(); + if(company== null || StringUtils.isBlank( company.getEmail()) || !Constants.equalsInteger(company.getSignStatus(),Constants.ONE)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧凤紝浼佷笟灏氭湭鍏峰鍦ㄧ嚎绛剧珷鏉′欢锛岃鑱旂郴骞冲彴绠$悊鍛樼‘璁"); + } + + String fileUrl = ExcelExporter.build(ApplyChange.class).exportChangeUnitExcelToPdf(model,"缂撳瓨鐢宠琛�"); + String notifyUrl = systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.SIGN_DONE_NOTIFY_URL).getCode(); + notifyUrl = notifyUrl.replace("${type}","0").replace("${id}",model.getId().toString()); + String applyNo = signService.applySignLocalFile(company.getName(),fileUrl,company.getName(),company.getCode(),company.getEmail(),null,company.getSignId(),notifyUrl); + if(StringUtils.isBlank(applyNo) ){ + throw new BusinessException(ResponseStatus.SERVER_ERROR.getCode(),"瀵逛笉璧凤紝鑾峰彇鍦ㄧ嚎绛剧珷鍦板潃澶辫触锛岃绋嶅悗閲嶈瘯锛�"); + } + String link = signService.signLink(applyNo,company.getName(),company.getCode()); + if(StringUtils.isBlank(link) ){ + throw new BusinessException(ResponseStatus.SERVER_ERROR.getCode(),"瀵逛笉璧凤紝鑾峰彇鍦ㄧ嚎绛剧珷鍦板潃澶辫触锛岃绋嶅悗閲嶈瘯锛�"); + } + ApplyChange update= new ApplyChange(); + update.setId(model.getId()); + update.setEditor(user.getId()); + update.setEditDate(new Date()); + update.setSignApplyNo(applyNo); + applyChangeMapper.updateById(update); + return link; + } + /** + * 瀵煎嚭鍔犲噺淇濈敵璇疯〃 + * @param param + * @return + */ + @Override + public ApplyChange exportJiajianBaoExcel(ApplyChange param){ + + ApplyChange model = findJoinDetail(param); + if(Objects.isNull(model) ||! Constants.equalsInteger(Constants.ZERO,model.getType())){ + throw new BusinessException(ResponseStatus.DATA_EMPTY); + } + + //鏌ヨ鏄庣粏 + List<ApplyChagneDetail> detailList =findJoinDetailList(model); + model.setAddDetailList(new ArrayList<>()); + model.setDelDetailList(new ArrayList<>()); + if(detailList!=null){ + for(ApplyChagneDetail ad :detailList){ + if(Constants.equalsInteger(ad.getType(),Constants.ZERO)){ + model.getAddDetailList().add(ad); + }else{ + model.getDelDetailList().add(ad); + } + } + } + model.setDelNum(model.getDelDetailList().size()); + model.setAddNum(model.getAddDetailList().size()); + return model; + } + private ApplyChange findJoinDetail(ApplyChange param) { + MPJLambdaWrapper wrapper= new MPJLambdaWrapper<ApplyChange>() + .selectAll(ApplyChange.class) + .selectAs(Solutions::getName,ApplyChange::getSolutionsName) + .selectAs(Company::getName,ApplyChange::getCompanyName) + .selectAs(InsuranceApply::getCode,ApplyChange::getApplyCode) + .selectAs(InsuranceApply::getStartTime,ApplyChange::getStartTime) + .selectAs(InsuranceApply::getStartTime,ApplyChange::getEndTime) + .leftJoin(InsuranceApply.class,InsuranceApply::getId,ApplyChange::getApplyId) + .leftJoin(Solutions.class,Solutions::getId,InsuranceApply::getSolutionId) + .leftJoin(Company.class,Company::getId,ApplyChange::getCompanyId) + .eq(ApplyChange::getId,param.getId()) + .last("limit 1"); + + ApplyChange model = applyChangeJoinMapper.selectJoinOne(ApplyChange.class,wrapper); + return model; + } + private List<ApplyChagneDetail> findJoinDetailList(ApplyChange model) { + MPJLambdaWrapper wrapper1= new MPJLambdaWrapper<ApplyChagneDetail>() + .selectAll(ApplyChagneDetail.class) + .selectAs(Member::getName,ApplyChagneDetail::getMemberName) + .selectAs(Member::getSex,ApplyChagneDetail::getSex) + .selectAs(Member::getIdcardNo,ApplyChagneDetail::getIdcardNo) + .selectAs(Worktype::getName,ApplyChagneDetail::getWorkTypeName) + .selectAs(DispatchUnit::getName,ApplyChagneDetail::getDuName) + .leftJoin(Worktype.class,Worktype::getId,ApplyChagneDetail::getWorktypeId) + .leftJoin(DispatchUnit.class,DispatchUnit::getId,ApplyChagneDetail::getDuId) + .leftJoin(Member.class,Member::getId,ApplyChagneDetail::getMemberId) + .eq(ApplyChagneDetail::getIsdeleted,Constants.ZERO) + .eq(ApplyChagneDetail::getApplyChangeId,model.getId()); + //鏌ヨ鏄庣粏 + List<ApplyChagneDetail> detailList =applyChagneDetailJoinMapper.selectJoinList(ApplyChagneDetail.class,wrapper1); + return detailList; + } + private List<ApplyChagneDetail> findJoinChangeDetailList(ApplyChange model) { + MPJLambdaWrapper wrapper1= new MPJLambdaWrapper<ApplyChagneDetail>() + .selectAll(ApplyChagneDetail.class) + .selectAs(Member::getName,ApplyChagneDetail::getMemberName) + .selectAs(Member::getSex,ApplyChagneDetail::getSex) + .select("t1.name as worktypeName") + .select("t2.name as duName") + .select("t3.name as oldWorktypeName") + .select("t4.name as oldDuName") + .selectAs(Member::getSex,ApplyChagneDetail::getSex) + .selectAs(Member::getIdcardNo,ApplyChagneDetail::getIdcardNo) + .leftJoin(Worktype.class,Worktype::getId,ApplyChagneDetail::getWorktypeId) + .leftJoin(DispatchUnit.class,DispatchUnit::getId,ApplyChagneDetail::getDuId) + .leftJoin(Worktype.class,Worktype::getId,ApplyChagneDetail::getOldWorktypeId) + .leftJoin(DispatchUnit.class,DispatchUnit::getId,ApplyChagneDetail::getOldDuId) + .leftJoin(Member.class,Member::getId,ApplyChagneDetail::getMemberId) + .eq(ApplyChagneDetail::getIsdeleted,Constants.ZERO) + .eq(ApplyChagneDetail::getApplyChangeId,model.getId()); + //鏌ヨ鏄庣粏 + List<ApplyChagneDetail> detailList =applyChagneDetailJoinMapper.selectJoinList(ApplyChagneDetail.class,wrapper1); + return detailList; + } } -- Gitblit v1.9.3