package com.dy.pmsStation.assemblyStep; 
 | 
  
 | 
import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; 
 | 
import com.baomidou.mybatisplus.core.toolkit.StringUtils; 
 | 
import com.dy.pmsGlobal.daoOth.OthFileMapper; 
 | 
import com.dy.pmsGlobal.daoPlt.*; 
 | 
import com.dy.pmsGlobal.daoPr.PrAssemblyPlanMapper; 
 | 
import com.dy.pmsGlobal.daoPr.PrProductionNodeMapper; 
 | 
import com.dy.pmsGlobal.daoSta.*; 
 | 
import com.dy.pmsGlobal.daoTst.TstCommandMapper; 
 | 
import com.dy.pmsGlobal.dyFile.FileOperate; 
 | 
import com.dy.pmsGlobal.dyFile.FileRestVo; 
 | 
import com.dy.pmsGlobal.pojoOth.OthFile; 
 | 
import com.dy.pmsGlobal.pojoPlt.*; 
 | 
import com.dy.pmsGlobal.pojoPr.PrAssemblyPlan; 
 | 
import com.dy.pmsGlobal.pojoPr.PrBillOfMaterial; 
 | 
import com.dy.pmsGlobal.pojoPr.PrProductionNode; 
 | 
import com.dy.pmsGlobal.pojoPr.PrWorkingInstruction; 
 | 
import com.dy.pmsGlobal.pojoSta.*; 
 | 
import com.dy.pmsGlobal.pojoTst.TstCommand; 
 | 
import com.dy.pmsGlobal.util.DeviceResult; 
 | 
import com.dy.pmsGlobal.util.DeviceStatus; 
 | 
import com.dy.pmsGlobal.util.QrCodeConstant; 
 | 
import com.dy.pmsGlobal.util.UserUtil; 
 | 
import lombok.extern.slf4j.Slf4j; 
 | 
import org.apache.dubbo.common.utils.PojoUtils; 
 | 
import org.springframework.beans.BeanUtils; 
 | 
import org.springframework.beans.factory.annotation.Autowired; 
 | 
import org.springframework.beans.factory.annotation.Value; 
 | 
import org.springframework.stereotype.Service; 
 | 
import org.springframework.transaction.annotation.Transactional; 
 | 
  
 | 
import java.math.BigInteger; 
 | 
import java.util.*; 
 | 
import java.util.stream.Collectors; 
 | 
  
 | 
@Slf4j 
 | 
@Service 
 | 
public class AssemblyStepSv { 
 | 
    private static final String WORK_TYPE_ASSEMBLY = "1"; 
 | 
    private static final String WORK_TYPE_TEST = "2"; 
 | 
    private static final String WORK_TYPE_INSPECTION = "3"; 
 | 
    private static final String WORK_TYPE_REPAIR = "4"; 
 | 
    private static final String WORK_TYPE_OTHER = "5"; 
 | 
  
 | 
    private StaDeviceLastMapper deviceLastDao; 
 | 
    private StaDeviceLifeMapper deviceLifeDao; 
 | 
    private StaDeviceLifeLastMapper deviceLifeLastDao; 
 | 
    private StaWipSnExMapper wipSnExDao; 
 | 
    private StaDeviceProductionLogMapper deviceProductionLogDao; 
 | 
    private StaAssemblyWorkLastMapper assemblyWorkLastDao; 
 | 
    private PrAssemblyPlanMapper assemblyPlanDao; 
 | 
    //    private PrProductionProcessMapper processDao; 
 | 
    private PrProductionNodeMapper nodeDao; 
 | 
    private StaRepairInfoMapper repairInfoDao; 
 | 
    private PltProductQualityInspectionItemsMapper qualityItemsDao; 
 | 
    private PltProductTestInspectionItemsMapper testItemsDao; 
 | 
    private TstCommandMapper tstCommandDao; 
 | 
    private PltProductMapper productDao; 
 | 
    private PltProParamsMapper paramsDao; 
 | 
    private PltProductFileMapper productFileDao; 
 | 
    private FileOperate fileOperate; 
 | 
    private OthFileMapper othFileMapper; 
 | 
    @Value("${dy.webFile.fmUrl}") 
 | 
    private String fmUrl; 
 | 
  
 | 
    @Autowired 
 | 
    public void setDeviceLastDao(StaDeviceLastMapper deviceLastDao) { 
 | 
        this.deviceLastDao = deviceLastDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setDeviceLifeDao(StaDeviceLifeMapper deviceLifeDao) { 
 | 
        this.deviceLifeDao = deviceLifeDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setWipSnExDao(StaWipSnExMapper wipSnExDao) { 
 | 
        this.wipSnExDao = wipSnExDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setDeviceProductionLogDao(StaDeviceProductionLogMapper deviceProductionLogDao) { 
 | 
        this.deviceProductionLogDao = deviceProductionLogDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setAssemblyWorkLastDao(StaAssemblyWorkLastMapper assemblyWorkLastDao) { 
 | 
        this.assemblyWorkLastDao = assemblyWorkLastDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setAssemblyPlanDao(PrAssemblyPlanMapper assemblyPlanDao) { 
 | 
        this.assemblyPlanDao = assemblyPlanDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setNodeDao(PrProductionNodeMapper nodeDao) { 
 | 
        this.nodeDao = nodeDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setRepairInfoDao(StaRepairInfoMapper repairInfoDao) { 
 | 
        this.repairInfoDao = repairInfoDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setQualityItemsDao(PltProductQualityInspectionItemsMapper qualityItemsDao) { 
 | 
        this.qualityItemsDao = qualityItemsDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setTestItemsDao(PltProductTestInspectionItemsMapper testItemsDao) { 
 | 
        this.testItemsDao = testItemsDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setProductDao(PltProductMapper productDao) { 
 | 
        this.productDao = productDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setParamsDao(PltProParamsMapper paramsDao) { 
 | 
        this.paramsDao = paramsDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setProductFileDao(PltProductFileMapper productFileDao) { 
 | 
        this.productFileDao = productFileDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setFileOperate(FileOperate fileOperate) { 
 | 
        this.fileOperate = fileOperate; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setOthFileMapper(OthFileMapper othFileMapper) { 
 | 
        this.othFileMapper = othFileMapper; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setDeviceLifeLastDao(StaDeviceLifeLastMapper deviceLifeLastDao) { 
 | 
        this.deviceLifeLastDao = deviceLifeLastDao; 
 | 
    } 
 | 
  
 | 
    @Autowired 
 | 
    public void setTstCommandDao(TstCommandMapper tstCommandDao) { 
 | 
        this.tstCommandDao = tstCommandDao; 
 | 
    } 
 | 
  
 | 
    @Transactional 
 | 
    public int save(QueryVo params) { 
 | 
        long workId = Long.parseLong(params.workId); 
 | 
        StaAssemblyWorkLast workLast = assemblyWorkLastDao.selectByPrimaryKey(workId); 
 | 
        if (workLast == null) { 
 | 
            throw new RuntimeException("系统中没有该条登录信息");//工单不存在 
 | 
        } 
 | 
        PrAssemblyPlan plan = assemblyPlanDao.selectByPrimaryKey(workLast.getPlanId()); 
 | 
        // 验证并处理设备号和物料号 
 | 
        Set<String> deviceSet = new HashSet<>(Arrays.asList(params.deviceNo)); 
 | 
        // 分类设备号和物料号 
 | 
        List<String> deviceList = new ArrayList<>(); 
 | 
        List<Map<String, String>> materialList = new ArrayList<>(); 
 | 
        List<PltProduct> productList = productDao.selectAll(null); 
 | 
        deviceSet.forEach(deviceNo -> { 
 | 
            if (deviceNo.contains(plan.batchNo)) { 
 | 
                deviceList.add(deviceNo); 
 | 
            } else { 
 | 
                //判断是不是是本厂物料,如果是,则添加物料到ex表中 
 | 
                Map<String, String> result = queryByDeviceNo(deviceNo, productList); 
 | 
                if (StringUtils.isNotBlank(result.get("proName"))) { 
 | 
                    materialList.add(result); 
 | 
                } 
 | 
            } 
 | 
        }); 
 | 
  
 | 
        if (deviceList.isEmpty()) { 
 | 
            throw new RuntimeException("设备号(" + Arrays.toString(params.deviceNo) + ")均不属于当前任务计划"); 
 | 
        } 
 | 
        if (deviceList.size() > 1) { 
 | 
            throw new RuntimeException("在产设备(" + deviceList.stream().collect(Collectors.joining(",")) + ")有且只能有一个属于当前任务计划"); 
 | 
        } 
 | 
  
 | 
        StaDeviceLast deviceLast = buildDeviceLast(params, workLast, deviceList.get(0)); 
 | 
        int count = deviceLast.id == null ? deviceLastDao.insertSelective(deviceLast) : 
 | 
                deviceLastDao.updateByPrimaryKey(deviceLast); 
 | 
  
 | 
        saveDeviceProductionLog(deviceLast); 
 | 
  
 | 
        PrProductionNode node = nodeDao.selectByPrimaryKey(workLast.nodeId); 
 | 
        if (node.isRecord) { 
 | 
            saveDeviceLife(deviceLast); 
 | 
        } 
 | 
        if (CollectionUtils.isNotEmpty(materialList)) { 
 | 
            saveSnEx(workLast, deviceList, materialList); 
 | 
        } 
 | 
        return count; 
 | 
    } 
 | 
  
 | 
    private void saveDeviceProductionLog(StaDeviceLast deviceLast) { 
 | 
        StaDeviceProductionLog log = new StaDeviceProductionLog(); 
 | 
        BeanUtils.copyProperties(deviceLast, log); 
 | 
        log.setId(null); // 设备生产日志ID设为null,表示新增 
 | 
        deviceProductionLogDao.insertSelective(log); 
 | 
    } 
 | 
  
 | 
    private void saveDeviceLife(StaDeviceLast deviceLast) { 
 | 
        StaDeviceLife life = new StaDeviceLife(); 
 | 
        BeanUtils.copyProperties(deviceLast, life); 
 | 
        life.setId(null); 
 | 
        deviceLifeDao.insertSelective(life); 
 | 
  
 | 
        StaDeviceLifeLast lastLife = new StaDeviceLifeLast(); 
 | 
        BeanUtils.copyProperties(deviceLast, lastLife); 
 | 
        lastLife.setId(null); 
 | 
        int count = deviceLifeLastDao.updateByDeviceNo(lastLife); 
 | 
        if (count == 0) { 
 | 
            deviceLifeLastDao.insertSelective(lastLife); 
 | 
        } 
 | 
    } 
 | 
  
 | 
    private StaDeviceLast buildDeviceLast(QueryVo params, StaAssemblyWorkLast workLast, String deviceNo) { 
 | 
        //组装数据 
 | 
        StaDeviceLast record = new StaDeviceLast(); 
 | 
        //pr_assembly_plan input_number +1  投入数加1   根据deviceNo 找到对应任务 
 | 
        PrAssemblyPlan assemblyPlan = queryPlanByDeviceNo(deviceNo); //PrAssemblyPlan assemblyPlan = assemblyPlanDao.selectByPrimaryKey(workLast.planId); 
 | 
        StaDeviceLast preRecord = deviceLastDao.selectByDeviceNo(deviceNo); 
 | 
        if (preRecord != null) { 
 | 
            record.id = preRecord.id; 
 | 
            record.inTime = preRecord.outTime; 
 | 
            record.inLineTime = preRecord.inLineTime; 
 | 
            record.outLineTime = preRecord.outLineTime;//下边判断是否结束会用到 得留着 
 | 
        } else { 
 | 
            record.inTime = new Date(); 
 | 
            record.inLineTime = new Date(); 
 | 
            assemblyPlan.setInputNumber(assemblyPlan.getInputNumber() + 1); 
 | 
        } 
 | 
        record.outTime = new Date(); 
 | 
        record.planId = assemblyPlan.getId(); 
 | 
        record.workId = Long.parseLong(params.workId); 
 | 
        record.stationId = workLast.stationId; 
 | 
        record.deviceNo = deviceNo; 
 | 
        record.currNode = workLast.nodeId; 
 | 
        record.updatedBy = workLast.userId; 
 | 
        record.assistants = workLast.assistants; 
 | 
        record.errorMsg = params.errorMsg; 
 | 
  
 | 
        Boolean isEnd = false;//是否经历过或正在经历结束节点 
 | 
        if (workLast.nodeId == null) { 
 | 
            if (record.outLineTime != null) { 
 | 
                isEnd = true; 
 | 
            } 
 | 
            if(StringUtils.isNotBlank(params.getContent())){ 
 | 
                record.nodeContent = params.getContent(); 
 | 
            } 
 | 
        } else { 
 | 
            PrProductionNode node = nodeDao.selectByPrimaryKey(workLast.nodeId); 
 | 
            record.nodeContent = node.content; 
 | 
            PrProductionNode nextNode = nodeDao.selectNodeBySort(node.getProcessId() , (node.getSort() + 1)); 
 | 
            record.nextNodeContent = nextNode.content; 
 | 
            record.nextNode = nextNode.id; 
 | 
            if (node.isRecord) { 
 | 
                record.deviceCycleContent = node.deviceCycleContent; 
 | 
            } 
 | 
            if (node.getIsEnd() && record.outLineTime == null) { 
 | 
                record.outLineTime = new Date(); 
 | 
                assemblyPlan.setOutputNumber(assemblyPlan.getOutputNumber() + 1); 
 | 
                isEnd = true; 
 | 
            } else if (record.outLineTime != null) { 
 | 
                isEnd = true; 
 | 
            } 
 | 
        } 
 | 
        record.status = getStatus(params.status, isEnd, workLast.workType.toString()); 
 | 
        record.result = getResult(params.status, workLast.workType.toString()); 
 | 
        assemblyPlanDao.updateByPrimaryKeySelective(assemblyPlan); 
 | 
        return record; 
 | 
    } 
 | 
  
 | 
    private void saveSnEx(StaAssemblyWorkLast workLast, List<String> deviceList, List<Map<String, String>> materialList) { 
 | 
        for (Map<String, String> material : materialList) { 
 | 
            StaWipSnEx snEx = new StaWipSnEx(); 
 | 
            snEx.deviceNo = deviceList.get(0); 
 | 
            snEx.productNo = material.get("deviceNo"); 
 | 
            snEx.productName = material.get("proName"); 
 | 
            snEx.productId = Long.parseLong(material.get("proId")); 
 | 
            snEx.createTime = workLast.startTime; 
 | 
            snEx.createBy = workLast.userId; 
 | 
  
 | 
            wipSnExDao.insertSelective(snEx); 
 | 
        } 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 原状态: 0:待生产,1:组装中,2:完成,3:维修,4:报废,5:测试不通过,6:品检不通过 
 | 
     * 20240717当前状态  状态: 1, 组装中,2:完成,3:维修,4:报废 
 | 
     * 
 | 
     * @param status 状态 
 | 
     * @param isEnd  是否经历过结束节点 
 | 
     * @return 状态 
 | 
     */ 
 | 
    private Integer getStatus(String status, boolean isEnd, String workType) { 
 | 
        //组装   2024/07/17 目前组装workType 1 只有MarkOk     //测试    //品检 
 | 
        if (WORK_TYPE_ASSEMBLY.equals(workType) || WORK_TYPE_TEST.equals(workType) || WORK_TYPE_INSPECTION.equals(workType) || WORK_TYPE_REPAIR.equals(workType)|| WORK_TYPE_OTHER.equals(workType)) { 
 | 
            return switch (status) { 
 | 
                case QrCodeConstant.MarkOk -> isEnd ? DeviceStatus.COMPLETED.getCode() : DeviceStatus.ASSEMBLING.getCode(); 
 | 
                case QrCodeConstant.MarkQualified -> isEnd ? DeviceStatus.COMPLETED.getCode() : DeviceStatus.ASSEMBLING.getCode(); 
 | 
                case QrCodeConstant.MarkUnqualified -> DeviceStatus.REPAIR.getCode(); 
 | 
                case QrCodeConstant.MarkWaste -> DeviceStatus.WASTE.getCode(); 
 | 
                default -> throw new RuntimeException("状态错误"); 
 | 
            }; 
 | 
        } 
 | 
        //维修 
 | 
        throw new RuntimeException("状态错误,无效的节点类型: " + workType); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 结果: 1:通过,2:测试通过,3:品检通过,4:维修通过,5:测试不通过,6:品检不通过,7:报废 
 | 
     * 
 | 
     * @param status 前端出来的状态 
 | 
     * @return 结果 
 | 
     */ 
 | 
    private Integer getResult(String status, String workType) { 
 | 
        //组装  临时任务-其他 
 | 
        if (WORK_TYPE_ASSEMBLY.equals(workType) || WORK_TYPE_OTHER.equals(workType)) { 
 | 
            return switch (status) { 
 | 
                case QrCodeConstant.MarkOk -> DeviceResult.PASS.getCode(); 
 | 
                default -> throw new RuntimeException("状态错误"); 
 | 
            }; 
 | 
            //测试 
 | 
        } else if (WORK_TYPE_TEST.equals(workType)) { 
 | 
            return switch (status) { 
 | 
                case QrCodeConstant.MarkQualified -> DeviceResult.TEST_PASS.getCode(); 
 | 
                case QrCodeConstant.MarkUnqualified -> DeviceResult.TEST_FAIL.getCode(); 
 | 
                default -> throw new RuntimeException("状态错误"); 
 | 
            }; 
 | 
            //品检 
 | 
        } else if (WORK_TYPE_INSPECTION.equals(workType)) { 
 | 
            return switch (status) { 
 | 
                case QrCodeConstant.MarkQualified -> DeviceResult.INSPECTION_PASS.getCode(); 
 | 
                case QrCodeConstant.MarkUnqualified -> DeviceResult.INSPECTION_FAIL.getCode(); 
 | 
                default -> throw new RuntimeException("状态错误"); 
 | 
            }; 
 | 
            //维修 
 | 
        } else if (WORK_TYPE_REPAIR.equals(workType)) { 
 | 
            return switch (status) { 
 | 
                case QrCodeConstant.MarkOk -> DeviceResult.REPAIR_PASS.getCode(); 
 | 
                case QrCodeConstant.MarkWaste -> DeviceResult.WASTE.getCode(); 
 | 
                default -> throw new RuntimeException("状态错误"); 
 | 
            }; 
 | 
        } 
 | 
        throw new RuntimeException("状态错误,无效的节点类型: " + workType); 
 | 
    } 
 | 
  
 | 
    @Transactional 
 | 
    public int repair(QueryVo vo) { 
 | 
        long workId = Long.parseLong(vo.workId); 
 | 
        StaAssemblyWorkLast workLast = assemblyWorkLastDao.selectByPrimaryKey(workId); 
 | 
        if (workLast == null) { 
 | 
            throw new RuntimeException("系统中没有该条登录信息"); 
 | 
        } 
 | 
        StaDeviceLast preDeviceRecord = deviceLastDao.selectByDeviceNo(vo.deviceNo[0]); 
 | 
        StaRepairInfo repairInfo = new StaRepairInfo(); 
 | 
        repairInfo.workId = workId; 
 | 
        repairInfo.deviceNo = vo.deviceNo[0]; 
 | 
        repairInfo.repairTime = new Date(); 
 | 
        repairInfo.repairBy = workLast.userId; 
 | 
        repairInfo.repairReason = vo.errorMsg; 
 | 
        if (preDeviceRecord != null) { 
 | 
            repairInfo.fromNode = preDeviceRecord.currNode; 
 | 
        } 
 | 
        repairInfoDao.insertSelective(repairInfo); 
 | 
  
 | 
        StaDeviceLast deviceLast = buildDeviceLast(vo, workLast, vo.deviceNo[0]); 
 | 
        deviceLast.setRepairId(repairInfo.getId()); 
 | 
        int count = deviceLast.id == null ? deviceLastDao.insertSelective(deviceLast) : 
 | 
                deviceLastDao.updateByPrimaryKey(deviceLast); 
 | 
        saveDeviceProductionLog(deviceLast); 
 | 
        //只要经历过结束节点,就一直记录device life 
 | 
        if (preDeviceRecord != null && preDeviceRecord.getOutLineTime() != null) { 
 | 
            saveDeviceLife(deviceLast); 
 | 
        } 
 | 
        return count; 
 | 
    } 
 | 
  
 | 
    @Transactional 
 | 
    public int testing(QueryVo vo) { 
 | 
        long workId = Long.parseLong(vo.workId); 
 | 
        StaAssemblyWorkLast workLast = assemblyWorkLastDao.selectByPrimaryKey(workId); 
 | 
        if (workLast == null) { 
 | 
            throw new RuntimeException("系统中没有该条登录信息"); 
 | 
        } 
 | 
        StaDeviceLast deviceLast = buildDeviceLast(vo, workLast, vo.deviceNo[0]); 
 | 
        int count = deviceLast.id == null ? deviceLastDao.insertSelective(deviceLast) : 
 | 
                deviceLastDao.updateByPrimaryKey(deviceLast); 
 | 
        saveDeviceProductionLog(deviceLast); 
 | 
        PrProductionNode node = nodeDao.selectByPrimaryKey(workLast.nodeId); 
 | 
        if (node != null && node.isRecord) { 
 | 
            saveDeviceLife(deviceLast); 
 | 
        } 
 | 
        return count; 
 | 
    } 
 | 
  
 | 
    @Transactional 
 | 
    public int inspectQuality(QueryVo vo) { 
 | 
        long workId = Long.parseLong(vo.workId); 
 | 
        StaAssemblyWorkLast workLast = assemblyWorkLastDao.selectByPrimaryKey(workId); 
 | 
        if (workLast == null) { 
 | 
            throw new RuntimeException("系统中没有该条登录信息"); 
 | 
        } 
 | 
        StaDeviceLast deviceLast = buildDeviceLast(vo, workLast, vo.deviceNo[0]); 
 | 
        int count = deviceLast.id == null ? deviceLastDao.insertSelective(deviceLast) : 
 | 
                deviceLastDao.updateByPrimaryKey(deviceLast); 
 | 
        saveDeviceProductionLog(deviceLast); 
 | 
        PrProductionNode node = nodeDao.selectByPrimaryKey(workLast.nodeId); 
 | 
        if (node != null && node.isRecord) { 
 | 
            saveDeviceLife(deviceLast); 
 | 
        } 
 | 
        return count; 
 | 
    } 
 | 
  
 | 
    //无任务计划中的其他 传workId ,手写工作内容 , 数量 
 | 
    @Transactional 
 | 
    public int otherWork(QueryVo vo) { 
 | 
        long workId = Long.parseLong(vo.workId); 
 | 
        StaAssemblyWorkLast workLast = assemblyWorkLastDao.selectByPrimaryKey(workId); 
 | 
        if (workLast == null) { 
 | 
            throw new RuntimeException("系统中没有该条登录信息"); 
 | 
        } 
 | 
        int count = 0; 
 | 
        //保存工作记录 //如果有设备码 
 | 
        if(vo.deviceNo != null && StringUtils.isNotBlank(vo.deviceNo[0])){ 
 | 
            StaDeviceLast deviceLast = buildDeviceLast(vo, workLast, vo.deviceNo[0]); 
 | 
            count = deviceLast.id == null ? deviceLastDao.insertSelective(deviceLast) : 
 | 
                    deviceLastDao.updateByPrimaryKey(deviceLast); 
 | 
            saveDeviceProductionLog(deviceLast); 
 | 
        }else{ 
 | 
            StaDeviceProductionLog log = new StaDeviceProductionLog(); 
 | 
            log.setId(null); // 设备生产日志ID设为null,表示新增 
 | 
            log.setDeviceNo("");  //RepairId  planId  currNode deviceCycleContent  memo 
 | 
            log.setWorkId(workId); 
 | 
            log.setStationId(workLast.getStationId()); 
 | 
            log.setNodeContent(vo.getContent()); 
 | 
            log.setStatus(DeviceStatus.COMPLETED.getCode());//完成状态 
 | 
            log.setResult(DeviceResult.PASS.getCode());//通过 
 | 
            log.setErrorMsg(vo.getErrorMsg()); 
 | 
            log.setAssistants(workLast.getAssistants()); 
 | 
            log.setInTime(new Date()); 
 | 
            log.setOutTime(new Date()); 
 | 
            log.setUpdatedBy(workLast.getUserId()); 
 | 
            log.setNumber(vo.getNumber()); 
 | 
            count = deviceProductionLogDao.insertSelective(log); 
 | 
  
 | 
        } 
 | 
        return count; 
 | 
    } 
 | 
  
 | 
    //根据节点查出节点作业指导书 
 | 
    public PrProductionNode getSopByNodeId(String nodeId) { 
 | 
        if (com.alibaba.excel.util.StringUtils.isBlank(nodeId)) { 
 | 
            throw new RuntimeException("节点ID不能为空"); 
 | 
        } 
 | 
        PrProductionNode node = nodeDao.selectByPrimaryKey(Long.parseLong(nodeId)); 
 | 
        if (node == null) { 
 | 
            throw new RuntimeException("节点ID不存在,请检查"); 
 | 
        } 
 | 
        if (node.instruction != null) { 
 | 
            addUrl(node.instruction); 
 | 
        } 
 | 
        if (node.bill != null) { 
 | 
            addBillUrl(node.bill); 
 | 
        } 
 | 
        return node; 
 | 
    } 
 | 
  
 | 
    //主要技术参数    俩个方法同 platform-->product-->productSv 
 | 
    public List<PltProductParams> getParamsByProId(String proId) { 
 | 
        if (StringUtils.isBlank(proId)) { 
 | 
            throw new RuntimeException("产品ID不能为空"); 
 | 
        } 
 | 
        List<PltProductParams> proParams = paramsDao.selectParams(Long.parseLong(proId)); 
 | 
        return proParams; 
 | 
    } 
 | 
  
 | 
    // 根据产品查出产品文件 
 | 
    public List<PltProductFile> getFileByProId(String proId) { 
 | 
        if (StringUtils.isBlank(proId)) { 
 | 
            throw new RuntimeException("产品ID不能为空"); 
 | 
        } 
 | 
        List<PltProductFile> proFiles = productFileDao.selectDocuments(Long.parseLong(proId)); 
 | 
        proFiles.stream().forEach(doc -> { 
 | 
            OthFile file = othFileMapper.selectByPrimaryKey(doc.fileId); 
 | 
            if (file == null) { 
 | 
                return; 
 | 
            } 
 | 
            FileRestVo fileRestVo = fileOperate.parseHashcode(fmUrl, file.hash); 
 | 
            doc.webUrl = fileRestVo.fileWebDownloadPath + doc.fileId; 
 | 
            doc.orgName = file.orgName; 
 | 
            doc.extName = file.extName; 
 | 
        }); 
 | 
        return proFiles; 
 | 
    } 
 | 
  
 | 
    public List<PltProductQualityInspectionItems> getQualityItems(String proId) { 
 | 
        Map<String, Object> params = new HashMap<>(); 
 | 
        params.put("proId", proId);//item  start  count 
 | 
        params.put("disabled", "0"); 
 | 
        //查询符合条件的记录 
 | 
        return qualityItemsDao.selectSome(params); 
 | 
    } 
 | 
  
 | 
    public List<PltProductTestInspectionItems> getTestItems(String proId) { 
 | 
        Map<String, Object> params = new HashMap<>(); 
 | 
        params.put("proId", proId); 
 | 
        params.put("disabled", "0"); 
 | 
        return testItemsDao.selectSome(params); 
 | 
    } 
 | 
  
 | 
    private boolean isOurProduct(String deviceNo, List<PltProduct> products) { 
 | 
        if (StringUtils.isNotEmpty(deviceNo) && deviceNo.length() == 22) { 
 | 
            for (PltProduct product : products) { 
 | 
                if (deviceNo.startsWith(QrCodeConstant.TypeProduct + product.getCode())) { 
 | 
                    return true; 
 | 
                } 
 | 
            } 
 | 
        } 
 | 
        return false; 
 | 
    } 
 | 
  
 | 
    private void addUrl(PrWorkingInstruction ins) { 
 | 
        if (ins == null || ins.fileId == null) { 
 | 
            return; 
 | 
        } 
 | 
        OthFile file = othFileMapper.selectByPrimaryKey(ins.fileId); 
 | 
        if (file == null) { 
 | 
            return; 
 | 
        } 
 | 
        FileRestVo fileRestVo = fileOperate.parseHashcode(fmUrl, file.hash); 
 | 
        ins.webUrl = fileRestVo.fileWebDownloadPath + ins.fileId; 
 | 
        ins.orgName = file.orgName; 
 | 
        ins.extName = file.extName; 
 | 
    } 
 | 
  
 | 
//    private PltProduct addWebUrl(PltProduct pro) { 
 | 
//        if (pro != null) { 
 | 
//            if (pro.image != null) { 
 | 
//                String filePathWithWebUrl = getFilePathWithWebUrl(pro.image); 
 | 
//                pro.imageWebPath = filePathWithWebUrl; 
 | 
//                pro.imageWebPathZip = fileOperate.getImgFileZipPath(filePathWithWebUrl); 
 | 
//            } 
 | 
// 
 | 
//            pro.proFiles.stream().forEach(doc -> { 
 | 
//                OthFile file = othFileMapper.selectByPrimaryKey(doc.fileId); 
 | 
//                if (file == null) { 
 | 
//                    return; 
 | 
//                } 
 | 
//                FileRestVo fileRestVo = fileOperate.parseHashcode(fmUrl, file.hash); 
 | 
//                doc.webUrl = fileRestVo.fileWebDownloadPath + doc.fileId; 
 | 
//                doc.orgName = file.orgName; 
 | 
//                doc.extName = file.extName; 
 | 
//            }); 
 | 
//        } 
 | 
//        return pro; 
 | 
//    } 
 | 
  
 | 
    private String getFilePathWithWebUrl(Long fileId) { 
 | 
        OthFile file = othFileMapper.selectByPrimaryKey(fileId); 
 | 
        FileRestVo fileRestVo = fileOperate.parseHashcode(fmUrl, file.hash); 
 | 
        return fileRestVo.fileWebUrl + file.filePath; 
 | 
    } 
 | 
  
 | 
    public Map<String, String> queryByDeviceNo(String deviceNo, List<PltProduct> productList) { 
 | 
        Map<String, String> map = new HashMap<>(); 
 | 
        map.put("deviceNo", deviceNo); 
 | 
        map.put("proName", ""); 
 | 
        map.put("proType", ""); 
 | 
        map.put("proId", ""); 
 | 
        map.put("proCode", ""); 
 | 
        //判断是不是是本厂物料 
 | 
        if (CollectionUtils.isEmpty(productList)) { 
 | 
            productList = productDao.selectAll(null); 
 | 
        } 
 | 
        PltProduct product = null; 
 | 
        if (StringUtils.isNotEmpty(deviceNo) && deviceNo.length() == 22) { 
 | 
            product = productList.stream().filter(p -> deviceNo.startsWith(QrCodeConstant.TypeProduct + p.getCode())).findFirst().orElse(null); 
 | 
        } 
 | 
        if (product != null) { 
 | 
            map.put("deviceNo", deviceNo); 
 | 
            map.put("proName", product.getName()); 
 | 
            map.put("proType", product.getType()); 
 | 
            BigInteger proId = BigInteger.valueOf(product.getId()); 
 | 
            map.put("proId", proId.toString()); 
 | 
            map.put("proCode", product.getCode()); 
 | 
        } 
 | 
        return map; 
 | 
    } 
 | 
  
 | 
    //查询产品所在的任务 
 | 
    public PrAssemblyPlan queryPlanByDeviceNo(String deviceNo) { 
 | 
        String proCode = ""; 
 | 
        String lotCode = ""; 
 | 
        if (StringUtils.isNotEmpty(deviceNo) && deviceNo.length() == 22) { 
 | 
            proCode = deviceNo.substring(3, 6); 
 | 
            lotCode = deviceNo.substring(6, 15); 
 | 
        } 
 | 
        PrAssemblyPlan plan = assemblyPlanDao.selectByDeviceNo(proCode, lotCode); 
 | 
        if (plan != null) { 
 | 
            plan.setBatchNo(lotCode); 
 | 
        } 
 | 
        return plan; 
 | 
    } 
 | 
  
 | 
    public List<StaDeviceLife> queryLifeByDeviceNo(String deviceNo) { 
 | 
        return deviceLifeDao.selectByDeviceNo(deviceNo); 
 | 
    } 
 | 
  
 | 
    public List<StaDeviceProductionLog> queryLogByDeviceNo(String devoiceNo) { 
 | 
        return deviceProductionLogDao.selectByDeviceNo(devoiceNo); 
 | 
    } 
 | 
  
 | 
    private void addBillUrl(PrBillOfMaterial bill) { 
 | 
        if (bill == null || bill.fileId == null) { 
 | 
            return; 
 | 
        } 
 | 
        OthFile file = othFileMapper.selectByPrimaryKey(bill.fileId); 
 | 
        if (file == null) { 
 | 
            return; 
 | 
        } 
 | 
        FileRestVo fileRestVo = fileOperate.parseHashcode(fmUrl, file.hash); 
 | 
        bill.webUrl = fileRestVo.fileWebDownloadPath + bill.fileId; 
 | 
        bill.orgName = file.orgName; 
 | 
        bill.extName = file.extName; 
 | 
    } 
 | 
    public List<TstCommand> getCommand(String proId, int type) { 
 | 
        Map<String, Object> params = new HashMap<>(); 
 | 
        params.put("proId", proId); 
 | 
        params.put("type", type); 
 | 
        return tstCommandDao.selectSome(params); 
 | 
    } 
 | 
    public List<PltProduct> selectAll(QueryVo queryVo) { 
 | 
        Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo); 
 | 
        return productDao.selectAll(params); 
 | 
    } 
 | 
} 
 |