| | |
| | | package com.ruoyi.inspect.service.impl; |
| | | |
| | | import cn.hutool.core.bean.BeanUtil; |
| | | import cn.hutool.core.io.IoUtil; |
| | | import com.alibaba.excel.EasyExcel; |
| | | import com.alibaba.excel.support.ExcelTypeEnum; |
| | | import com.alibaba.excel.write.style.column.LongestMatchColumnWidthStyleStrategy; |
| | |
| | | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
| | | import com.ruoyi.common.core.domain.Result; |
| | | import com.ruoyi.common.core.domain.entity.SysDictData; |
| | | import com.ruoyi.common.enums.ContractType; |
| | | import com.ruoyi.common.oa.OAProcess; |
| | | import com.ruoyi.common.oa.OAProperty; |
| | | import com.ruoyi.common.oa.OAResult; |
| | |
| | | import com.ruoyi.inspect.service.InsUnqualifiedHandlerFileService; |
| | | import com.ruoyi.inspect.service.InsUnqualifiedHandlerService; |
| | | import com.ruoyi.inspect.vo.UnqualifiedHandlerVO; |
| | | import com.ruoyi.system.mapper.UserMapper; |
| | | import com.ruoyi.system.service.ISysDictDataService; |
| | | import com.ruoyi.system.service.ISysDictTypeService; |
| | | import com.ruoyi.system.service.UserService; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.apache.commons.lang3.StringUtils; |
| | | import org.springframework.beans.factory.annotation.Value; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Isolation; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | |
| | | import javax.annotation.Resource; |
| | | import javax.servlet.http.HttpServletResponse; |
| | | import java.io.InputStream; |
| | | import java.net.URLEncoder; |
| | | import java.nio.charset.StandardCharsets; |
| | | import java.time.LocalDate; |
| | | import java.time.format.DateTimeFormatter; |
| | | import java.util.ArrayList; |
| | | import java.util.HashMap; |
| | |
| | | response.reset(); |
| | | try{ |
| | | //查询字典 |
| | | List<SysDictData> materialPropType = sysDictTypeService.selectDictDataByType("material_prop_type"); |
| | | List<SysDictData> materialPropType = sysDictTypeService.selectDictDataByType("material_prop_type");//物料属性 |
| | | List<SysDictData> categoriesNoConformities = sysDictTypeService.selectDictDataByType("categories_no_conformities");//不合格分类 |
| | | List<SysDictData> attributionNoConformities = sysDictTypeService.selectDictDataByType("attribution_no_conformities");// 不合格归属 |
| | | //查询不合格处理记录 |
| | | IPage<UnqualifiedHandlerVO> pageList = pageList(new Page<>(-1, -1), unqualifiedHandlerDto); |
| | | List<InsUnqualifiedHandlerExcelData> records = pageList.getRecords().stream().map(m->{ |
| | | InsUnqualifiedHandlerExcelData handlerExcelData = new InsUnqualifiedHandlerExcelData(); |
| | | BeanUtil.copyProperties(m,handlerExcelData); |
| | | handlerExcelData.setMaterialProp(materialPropType.stream().filter(f-> StringUtils.equals(f.getDictValue(),handlerExcelData.getMaterialProp())).findFirst().orElse(new SysDictData()).getDictLabel()); |
| | | if(StringUtils.equals(handlerExcelData.getClassification(),"0")){ |
| | | handlerExcelData.setClassification("一类不合格"); |
| | | }else if(StringUtils.equals(handlerExcelData.getClassification(),"1")){ |
| | | handlerExcelData.setClassification("二类不合格"); |
| | | } |
| | | if(StringUtils.equals(handlerExcelData.getOffGradeAscription(),"0")){ |
| | | handlerExcelData.setOffGradeAscription("生产反馈不合格"); |
| | | }else if(StringUtils.equals(handlerExcelData.getOffGradeAscription(),"1")){ |
| | | handlerExcelData.setOffGradeAscription("检测不合格"); |
| | | } |
| | | handlerExcelData.setClassification(categoriesNoConformities.stream().filter(f-> StringUtils.equals(f.getDictValue(),handlerExcelData.getClassification())).findFirst().orElse(new SysDictData()).getDictLabel()); |
| | | handlerExcelData.setOffGradeAscription(attributionNoConformities.stream().filter(f-> StringUtils.equals(f.getDictValue(),handlerExcelData.getOffGradeAscription())).findFirst().orElse(new SysDictData()).getDictLabel()); |
| | | return handlerExcelData; |
| | | }).collect(Collectors.toList()); |
| | | //设置response |
| | |
| | | //获取不合格处理记录 |
| | | UnqualifiedHandlerVO vo = baseMapper.findById(pushOADto.getHandlerId()); |
| | | |
| | | if (vo.getRequestId() != null) { |
| | | throw new ErrorException("该不合格处理已提交过OA"); |
| | | } |
| | | |
| | | //提交oa相关字段赋值 |
| | | DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd"); |
| | | Map<String, String> mainFields = new HashMap<>(); |
| | | mainFields.put("bh", vo.getNo());//编号 |
| | | mainFields.put("gysmc", vo.getSupplierName());//供应商名称 |
| | | mainFields.put("wlmc", vo.getMaterialName());//物料名称 |
| | | mainFields.put("scpc", vo.getProductionBatch());//生产批次 |
| | | mainFields.put("dhsl", vo.getCargoQuantity());//到货数量 |
| | | mainFields.put("ggxh", vo.getSpecsModels());//规格型号 |
| | | mainFields.put("bjrq", vo.getInspectTime().format(formatter));//报检日期 |
| | | mainFields.put("fkr", SecurityUtils.getUsername());//反馈人 |
| | | mainFields.put("fkrq", vo.getFeedbackTime().format(formatter));//反馈日期 |
| | | mainFields.put("fl", vo.getClassification());//分类 |
| | | mainFields.put("bhggs", vo.getOffGradeAscription());//不合格归属 |
| | | mainFields.put("bhgqkms", vo.getUnqualifiedDesc());//不合格情况描述 |
| | | // mainFields.put("bh", vo.getNo());//编号 |
| | | // mainFields.put("gysmc", vo.getSupplierName());//供应商名称 |
| | | // mainFields.put("wlmc", vo.getMaterialName());//物料名称 |
| | | // mainFields.put("scpc", vo.getProductionBatch());//生产批次 |
| | | // mainFields.put("dhsl", vo.getCargoQuantity());//到货数量 |
| | | // mainFields.put("ggxh", vo.getSpecsModels());//规格型号 |
| | | // mainFields.put("bjrq", vo.getInspectTime().format(formatter));//报检日期 |
| | | // mainFields.put("fkr", SecurityUtils.getUsername());//反馈人 |
| | | // mainFields.put("fkrq", vo.getFeedbackTime().format(formatter));//反馈日期 |
| | | // mainFields.put("fl", vo.getClassification());//分类 |
| | | // mainFields.put("bhggs", vo.getOffGradeAscription());//不合格归属 |
| | | // mainFields.put("bhgqkms", vo.getUnqualifiedDesc());//不合格情况描述 |
| | | // mainFields.put("bh", vo.getNo());//编号 |
| | | mainFields.put("gysmcsuppliername", vo.getSupplierName());//供应商名称 |
| | | mainFields.put("wlmcmaterialname", vo.getMaterialName());//物料名称 |
| | | mainFields.put("scpcproductionbatch", vo.getProductionBatch());//生产批次 |
| | | mainFields.put("dhslcargoquantity", vo.getCargoQuantity());//到货数量 |
| | | mainFields.put("ggxhspecificationsmodels", vo.getSpecsModels());//规格型号 |
| | | mainFields.put("bjrqdeclarationinspectdate", vo.getInspectTime().format(formatter));//报检日期 |
| | | mainFields.put("fkrprovideroffeedback", SecurityUtils.getUsername());//反馈人 |
| | | mainFields.put("fkrqfeedbacktime", vo.getFeedbackTime().format(formatter));//反馈日期 |
| | | mainFields.put("flclassification", vo.getClassification());//分类 |
| | | mainFields.put("bhggsoffgradeascription", vo.getOffGradeAscription());//不合格归属 |
| | | mainFields.put("bhgqkmsunqualifieddescription", vo.getUnqualifiedDesc());//不合格情况描述 |
| | | |
| | | //查询附件 |
| | | List<InsUnqualifiedHandlerFile> handlerFiles = insUnqualifiedHandlerFileService.list(Wrappers.<InsUnqualifiedHandlerFile>lambdaQuery() |
| | |
| | | if (CollectionUtils.isNotEmpty(handlerFiles)) { |
| | | StringBuilder fileUrl = new StringBuilder(); |
| | | for (int i = 0; i < handlerFiles.size(); i++) { |
| | | String path = handlerFiles.get(i).getType().equals(1) ? "/lims/img/" : "/lims/word/"; |
| | | String path = handlerFiles.get(i).getType().equals(1) ? "/img/" : "/word/"; |
| | | if (i == handlerFiles.size() - 1) { |
| | | fileUrl.append("<a href='" + oaProperty.getProdIp()).append(path + handlerFiles.get(i).getFileUrl() |
| | | + "'target='_blank'>" + handlerFiles.get(i).getFileName() + "</a>"); |
| | |
| | | + "'target='_blank'>" + handlerFiles.get(i).getFileName() + "</a>").append("<br/>"); |
| | | } |
| | | } |
| | | mainFields.put("xlimsfj", fileUrl.toString()); |
| | | mainFields.put("fjlj", fileUrl.toString()); |
| | | } |
| | | //流程标题 |
| | | String requestName = vo.getHeadline(); |
| | |
| | | boolean oa = false; |
| | | try { |
| | | log.info("发起不合格处理OA审核流程"); |
| | | String unqualifiedProcessId = oaProperty.getUnqualifiedProcessId(); |
| | | //根据IFS域获取对应的流程id |
| | | if(StringUtils.isBlank(pushOADto.getContract())){ |
| | | throw new RuntimeException("IFS域【"+pushOADto.getContract()+"】不存在,OA流程提交失败"); |
| | | } |
| | | String unqualifiedProcessId = StringUtils.equals(ContractType.ZTNS.getValue(),pushOADto.getContract())?oaProperty.getUnqualifiedProcessId():oaProperty.getUnqualifiedProcessIdByKJNS(); |
| | | log.info("不合格流程请求参数:{},{},{},{}",mainFields, requestName, unqualifiedProcessId,SecurityUtils.getUsername()); |
| | | OAResult oaResult = OAProcess.start(mainFields, requestName, unqualifiedProcessId,SecurityUtils.getUsername()); |
| | | log.info("不合格处理OA审核流程结束,返回结果->{}" + oaResult); |
| | | log.info("不合格流程ID:{},不合格处理OA审核流程结束,返回结果->{}",unqualifiedProcessId,oaResult); |
| | | oa = oaResult.success(); |
| | | if (oa) { |
| | | String addWorkflowResult = oaResult.getAddWorkflowResult(); |
| | |
| | | * @return |
| | | */ |
| | | @Override |
| | | @Transactional(rollbackFor = Exception.class,isolation = Isolation.READ_COMMITTED) |
| | | public boolean updateUnqualifiedHandler(UnqualifiedHandlerDto unqualifiedHandlerDto) { |
| | | // 删除附件, 重新添加 |
| | | insUnqualifiedHandlerFileService.remove(Wrappers.<InsUnqualifiedHandlerFile>lambdaQuery() |
| | |
| | | } |
| | | insUnqualifiedHandlerFileService.updateBatchById(unqualifiedHandlerDto.getUnqualifiedHandlerFiles()); |
| | | } |
| | | |
| | | return this.updateById(unqualifiedHandlerDto); |
| | | boolean isUpdated = this.updateById(unqualifiedHandlerDto); |
| | | if(isUpdated){ |
| | | //推送OA |
| | | PushOADto pushOADto = new PushOADto(); |
| | | pushOADto.setHandlerId(unqualifiedHandlerDto.getId()); |
| | | pushOADto.setContract(unqualifiedHandlerDto.getContract()); |
| | | pushOA(pushOADto); |
| | | } |
| | | return true; |
| | | } |
| | | |
| | | /** |