/*
|
* Copyright (c) 2018-2025, ztt All rights reserved.
|
*
|
* Redistribution and use in source and binary forms, with or without
|
* modification, are permitted provided that the following conditions are met:
|
*
|
* Redistributions of source code must retain the above copyright notice,
|
* this list of conditions and the following disclaimer.
|
* Redistributions in binary form must reproduce the above copyright
|
* notice, this list of conditions and the following disclaimer in the
|
* documentation and/or other materials provided with the distribution.
|
* Neither the name of the pig4cloud.com developer nor the names of its
|
* contributors may be used to endorse or promote products derived from
|
* this software without specific prior written permission.
|
* Author: ztt
|
*/
|
package com.chinaztt.mes.basic.service.impl;
|
|
import cn.hutool.core.collection.CollectionUtil;
|
import cn.hutool.core.io.IoUtil;
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
import com.chinaztt.mes.basic.dto.ParamDTO;
|
import com.chinaztt.mes.basic.entity.Param;
|
import com.chinaztt.mes.basic.entity.ParamJoinTemplate;
|
import com.chinaztt.mes.basic.entity.Template;
|
import com.chinaztt.mes.basic.entity.TemplateTypeRelation;
|
import com.chinaztt.mes.basic.enums.FileEnums;
|
import com.chinaztt.mes.basic.mapper.BasicParamTemplateMapper;
|
import com.chinaztt.mes.basic.mapper.ParamJoinTemplateMapper;
|
import com.chinaztt.mes.basic.mapper.ParamMapper;
|
import com.chinaztt.mes.basic.service.BasicParamTemplateService;
|
import com.chinaztt.mes.basic.util.DictUtils;
|
import com.chinaztt.mes.common.numgen.NumberGenerator;
|
import com.chinaztt.mes.common.util.JsonUtil;
|
import com.chinaztt.ztt.admin.api.entity.SysDictItem;
|
import com.chinaztt.ztt.common.oss.service.OssTemplate;
|
import lombok.AllArgsConstructor;
|
import lombok.extern.slf4j.Slf4j;
|
import org.springframework.stereotype.Service;
|
import org.springframework.transaction.annotation.Transactional;
|
|
import javax.servlet.http.HttpServletResponse;
|
import java.io.FileInputStream;
|
import java.io.IOException;
|
import java.io.InputStream;
|
import java.util.*;
|
import java.util.stream.Collectors;
|
|
/**
|
* 工序模板
|
*
|
* @author sunxl
|
* @date 2021-03-25 13:25:43
|
*/
|
@Slf4j
|
@Service
|
@AllArgsConstructor
|
@Transactional(rollbackFor = Exception.class)
|
public class BasicParamTemplateServiceImpl extends ServiceImpl<BasicParamTemplateMapper, Template> implements BasicParamTemplateService {
|
private ParamMapper paramMapper;
|
private ParamJoinTemplateMapper paramJoinTemplateMapper;
|
private NumberGenerator<Template> templateNumberGenerator;
|
|
private final OssTemplate minioTemplate;
|
|
private DictUtils dictUtils;
|
|
@Override
|
public List<Map<String, Object>> getParamById(Page page, long technologyOperationTemplateId) {
|
QueryWrapper<ParamJoinTemplate>gen=new QueryWrapper<>();
|
gen.lambda().eq(ParamJoinTemplate::getParentId,0)
|
.eq(ParamJoinTemplate::getTechnologyOperationTemplateId,technologyOperationTemplateId);
|
List<ParamJoinTemplate> paramJoinTemplates = paramJoinTemplateMapper.selectList(gen);
|
if(paramJoinTemplates.size()<1){
|
return new ArrayList<>();
|
}
|
List<SysDictItem> dict = dictUtils.getDict("technology_param");
|
List<Long>longList=new ArrayList<>();
|
paramJoinTemplates.forEach(p->{
|
longList.add(p.getTechnologyOperationParamId());
|
});
|
//QueryWrapper<Param>queryWrapper=new QueryWrapper<>();
|
//queryWrapper.lambda().in(Param::getId,longList);
|
//List<Param> params = paramMapper.selectList(queryWrapper);
|
return getTree(longList,dict,technologyOperationTemplateId);
|
}
|
|
|
@Override
|
public boolean updateParameters(ParamJoinTemplate paramJoinTemplate) {
|
paramJoinTemplateMapper.updateParamValueJoinTemplate(paramJoinTemplate.getDefaultValue(), paramJoinTemplate.getTechnologyOperationParamId(), paramJoinTemplate.getTechnologyOperationTemplateId());
|
return true;
|
}
|
|
|
@Override
|
@Transactional(rollbackFor = Exception.class)
|
public List<Map<String, Object>> relateTypeTemplate(List<ParamJoinTemplate> operationParamJoinTemplate) {
|
List<ParamJoinTemplate> newOperationParamJoinTemplateList = new ArrayList<>();
|
List<ParamDTO> paramList = new ArrayList<>();
|
if (CollectionUtil.isNotEmpty(operationParamJoinTemplate)) {
|
List<ParamJoinTemplate> operationParamJoinTemplateList = paramJoinTemplateMapper.selectList(Wrappers.<ParamJoinTemplate>lambdaQuery().eq(ParamJoinTemplate::getTechnologyOperationTemplateId, operationParamJoinTemplate.get(0).getTechnologyOperationTemplateId()));
|
A:
|
for (ParamJoinTemplate newParamJoinTemplate : operationParamJoinTemplate) {
|
for (int i = 0; i < operationParamJoinTemplateList.size(); i++) {
|
if (newParamJoinTemplate.getTechnologyOperationParamId().equals(operationParamJoinTemplateList.get(i).getTechnologyOperationParamId())) {
|
paramJoinTemplateMapper.updateParamJoinTemplate(newParamJoinTemplate);
|
continue A;
|
}
|
}
|
newOperationParamJoinTemplateList.add(newParamJoinTemplate);
|
}
|
for (ParamJoinTemplate newOperationParam : newOperationParamJoinTemplateList) {
|
long firstId=newOperationParam.getTechnologyOperationParamId();
|
long templateId=newOperationParam.getTechnologyOperationTemplateId();
|
paramJoinTemplateMapper.insert(newOperationParam);
|
//二级参数
|
QueryWrapper<Param>queryWrapperSecond = new QueryWrapper<Param>();
|
queryWrapperSecond.lambda().eq(Param::getParentId,newOperationParam.getTechnologyOperationParamId());
|
List<Param> paramList1 = paramMapper.selectList(queryWrapperSecond);
|
if(paramList1.size()>0){
|
for (int i = 0; i < paramList1.size(); i++) {
|
Param secondParam = paramList1.get(i);
|
ParamJoinTemplate templateSecond=new ParamJoinTemplate();
|
templateSecond.setSort(i+1L);
|
templateSecond.setTechnologyOperationParamId(secondParam.getId());
|
templateSecond.setTechnologyOperationTemplateId(templateId);
|
templateSecond.setParentId(firstId);
|
paramJoinTemplateMapper.insert(templateSecond);
|
//三级参数
|
QueryWrapper<Param>queryWrapperThird = new QueryWrapper<Param>();
|
queryWrapperThird.lambda().eq(Param::getParentId,secondParam.getId());
|
List<Param> selectList = paramMapper.selectList(queryWrapperThird);
|
if(selectList.size()>0){
|
for (int j = 0; j < selectList.size(); j++) {
|
Param thirdParam = selectList.get(j);
|
ParamJoinTemplate templateThird=new ParamJoinTemplate();
|
templateThird.setSort(j+1L);
|
templateThird.setTechnologyOperationParamId(thirdParam.getId());
|
templateThird.setTechnologyOperationTemplateId(templateId);
|
templateThird.setParentId(secondParam.getId());
|
paramJoinTemplateMapper.insert(templateThird);
|
}
|
}
|
}
|
}
|
}
|
//paramList = paramMapper.getTemplateParam(operationParamJoinTemplate.get(0).getTechnologyOperationTemplateId());
|
}
|
List<SysDictItem> dict = dictUtils.getDict("technology_param");
|
QueryWrapper<ParamJoinTemplate>templateQueryWrapper=new QueryWrapper<>();
|
templateQueryWrapper.lambda().eq(ParamJoinTemplate::getParentId,0).select(ParamJoinTemplate::getTechnologyOperationParamId);
|
List<Long>longList=new ArrayList<>();
|
paramJoinTemplateMapper.selectList(templateQueryWrapper).forEach(p->{
|
longList.add(p.getTechnologyOperationParamId());
|
});
|
return getTree(longList,dict,operationParamJoinTemplate.get(0).getTechnologyOperationTemplateId());
|
}
|
|
public List<Map<String,Object>> getTree(List records,List<SysDictItem> dict,long templateId){
|
QueryWrapper<ParamJoinTemplate>templateQueryWrapper=new QueryWrapper<>();
|
templateQueryWrapper.lambda().eq(ParamJoinTemplate::getTechnologyOperationTemplateId,templateId);
|
List<ParamJoinTemplate> paramJoinTemplates = paramJoinTemplateMapper.selectList(templateQueryWrapper);
|
List<Map<String,Object>> all = new ArrayList<>();
|
records.forEach(l->{
|
//一级参数
|
Param paramFirst = paramMapper.selectById(Long.parseLong(String.valueOf(l)));
|
|
Map pojo = JsonUtil.jsonToPojo(JsonUtil.jsonToString(paramFirst), Map.class);
|
Optional.ofNullable(pojo.get("type")).ifPresent(o->{
|
pojo.put("type",dict.stream().filter(d-> Objects.equals(String.valueOf(d.getValue()),pojo.get("type"))).collect(Collectors.toList()).get(0).getLabel());
|
});
|
String id = String.valueOf(pojo.get("id"));
|
List<ParamJoinTemplate> collect = paramJoinTemplates.stream().filter(p -> Objects.equals(id, String.valueOf(p.getTechnologyOperationParamId()))).collect(Collectors.toList());
|
if(collect.size()>0) {
|
pojo.put("paramValue", collect.get(0).getDefaultValue());
|
}else {
|
pojo.put("paramValue", "");
|
}
|
QueryWrapper<Param>queryWrapper=new QueryWrapper<>();
|
queryWrapper.lambda().eq(Param::getParentId,pojo.get("id"));
|
List<Param> secondList = paramMapper.selectList(queryWrapper);
|
QueryWrapper<ParamJoinTemplate>queryWrapperTem=new QueryWrapper<>();
|
queryWrapperTem.lambda().eq(ParamJoinTemplate::getParentId,Long.valueOf(String.valueOf(l)));
|
List<ParamJoinTemplate> paramJoinTemplates1 = paramJoinTemplateMapper.selectList(queryWrapperTem);
|
//去除不相关的数据
|
secondList.removeIf(s -> paramJoinTemplates1.stream().noneMatch(p->Objects.equals(s.getId(),p.getTechnologyOperationParamId())));
|
//没有children直接添加
|
if(secondList.isEmpty()){
|
Map<String,Object> oneMap = new HashMap<>();
|
oneMap.put("code",pojo.get("code"));
|
oneMap.put("paramItem",pojo.get("parameterItem"));
|
oneMap.put("paramItemTwo","");
|
oneMap.put("paramItemThree","");
|
oneMap.put("oneId", com.chinaztt.mes.common.util.StringUtils.defaultString( String.valueOf(pojo.get("id")),""));
|
oneMap.put("paramType", com.chinaztt.mes.common.util.StringUtils.defaultString((String) pojo.get("type"),""));
|
oneMap.put("paramFormat", com.chinaztt.mes.common.util.StringUtils.defaultString((String) pojo.get("parameterFormat"),""));
|
oneMap.put("unit", com.chinaztt.mes.common.util.StringUtils.defaultString((String) pojo.get("unit"),""));
|
oneMap.put("parentId",pojo.get("parentId"));
|
List<ParamJoinTemplate> collectSecond = paramJoinTemplates.stream().filter(p -> Objects.equals(String.valueOf(pojo.get("id")),String.valueOf( p.getTechnologyOperationParamId()))).collect(Collectors.toList());
|
if(collectSecond.size()>0){
|
oneMap.put("paramValue",collectSecond.get(0).getDefaultValue());
|
}else {
|
oneMap.put("paramValue","");
|
}
|
all.add(oneMap);
|
}
|
secondList.forEach(s->{
|
Map second = JsonUtil.jsonToPojo(JsonUtil.jsonToString(s), Map.class);
|
List<ParamJoinTemplate> collectSecond = paramJoinTemplates.stream().filter(p -> Objects.equals(s.getId(), p.getTechnologyOperationParamId())).collect(Collectors.toList());
|
if(collectSecond.size()>0){
|
System.out.println("第二层遍历前=====》"+collectSecond.get(0).getDefaultValue());
|
if(!org.springframework.util.StringUtils.hasText(collectSecond.get(0).getDefaultValue())){
|
s.setParamValue("");
|
}else {
|
second.put("paramValue",collectSecond.get(0).getDefaultValue());
|
s.setParamValue(collectSecond.get(0).getDefaultValue());
|
}
|
}else {
|
second.put("paramValue","");
|
s.setParamValue("");
|
}
|
System.out.println("第二层遍历后=====》"+s.getParamValue());
|
Optional.ofNullable(second.get("type")).ifPresent(o->{
|
List<SysDictItem> collect1 = dict.stream().filter(d -> Objects.equals(String.valueOf(d.getValue()), second.get("type"))).collect(Collectors.toList());
|
if(collect1.size()>0){
|
s.setType(String.valueOf(collect1.get(0).getLabel()));
|
}
|
//second.put("type",dict.stream().filter(d-> Objects.equals(String.valueOf(d.getValue()),second.get("type"))).collect(Collectors.toList()).get(0).getLabel());
|
//s.setType(String.valueOf(second.get("type")));
|
});
|
QueryWrapper<Param>queryWrapperSecond=new QueryWrapper<>();
|
queryWrapperSecond.lambda().eq(Param::getParentId,second.get("id"));
|
List<Param> third = paramMapper.selectList(queryWrapperSecond);
|
QueryWrapper<ParamJoinTemplate>queryWrapperThird=new QueryWrapper<>();
|
queryWrapperThird.lambda().eq(ParamJoinTemplate::getParentId,Long.valueOf(String.valueOf(s.getId())));
|
List<ParamJoinTemplate> paramJoinTemplates2 = paramJoinTemplateMapper.selectList(queryWrapperThird);
|
third.removeIf(t -> paramJoinTemplates2.stream().noneMatch(p->Objects.equals(p.getTechnologyOperationParamId(),t.getId())));
|
System.out.println("=11111111111111111==========================================>"+Objects.equals(s.getParamValue(),"null"));
|
boolean thirdIsNull =third.isEmpty();
|
if(third.isEmpty()){
|
Param p = new Param();
|
p.setType(s.getType());
|
p.setParamValue(s.getParamValue());
|
//p.setParameterFormat(null);
|
//p.setParamValue(s.getParamValue());
|
p.setUnit(s.getUnit());
|
p.setParentId(s.getParentId());
|
third.add(p);
|
}
|
third.forEach(t->{
|
if(thirdIsNull){
|
System.out.println("第二层到第三层======》"+t.getParamValue());
|
}
|
Optional.ofNullable(t.getType()).ifPresent(o->{
|
List<SysDictItem> collect1 = dict.stream().filter(d -> Objects.equals(String.valueOf(d.getValue()), t.getType())).collect(Collectors.toList());
|
if(collect1.size()>0){
|
t.setType(collect1.get(0).getLabel());
|
}
|
});
|
Map<String,Object> allMap = new HashMap<>();
|
List<ParamJoinTemplate> collectThird = paramJoinTemplates.stream().filter(p -> Objects.equals(t.getId(), p.getTechnologyOperationParamId())).collect(Collectors.toList());
|
if(collectThird.size()>0&&!thirdIsNull){
|
System.out.println("第三层====================》"+collectThird.get(0));
|
if(!org.springframework.util.StringUtils.hasText(collectThird.get(0).getDefaultValue())){
|
t.setParamValue("");
|
}else {
|
t.setParamValue(collectThird.get(0).getDefaultValue());
|
}
|
}else {
|
if(!thirdIsNull) {
|
t.setParamValue("");
|
}
|
}
|
allMap.put("code",pojo.get("code"));
|
allMap.put("paramItem", com.chinaztt.mes.common.util.StringUtils.defaultString((String) pojo.get("parameterItem"),""));
|
allMap.put("oneId", com.chinaztt.mes.common.util.StringUtils.defaultString( String.valueOf(pojo.get("id")),""));
|
allMap.put("twoId", com.chinaztt.mes.common.util.StringUtils.defaultString( String.valueOf(second.get("id")) ,""));
|
allMap.put("threeId", com.chinaztt.mes.common.util.StringUtils.defaultString(String.valueOf(t.getId()),""));
|
allMap.put("paramItemTwo", com.chinaztt.mes.common.util.StringUtils.defaultString((String) second.get("parameterItem"),""));
|
allMap.put("paramItemThree", com.chinaztt.mes.common.util.StringUtils.defaultString(t.getParameterItem(),""));
|
allMap.put("paramType", com.chinaztt.mes.common.util.StringUtils.defaultString(t.getType(),""));
|
//allMap.put("paramFormat", com.chinaztt.mes.common.util.StringUtils.defaultString(t.getParameterFormat(),""));
|
allMap.put("unit", com.chinaztt.mes.common.util.StringUtils.defaultString(t.getUnit(),""));
|
allMap.put("parentId",t.getParentId());
|
allMap.put("paramValue",com.chinaztt.mes.common.util.StringUtils.defaultString(t.getParamValue(),""));
|
all.add(allMap);
|
});
|
});
|
});
|
return all;
|
}
|
|
|
@Override
|
public boolean deleteParamTemplate(ParamJoinTemplate operationParamJoinTemplate) {
|
System.out.println("------------------------->"+operationParamJoinTemplate);
|
return paramJoinTemplateMapper
|
.deleteByCondition( operationParamJoinTemplate.getTechnologyOperationParamId(),
|
operationParamJoinTemplate.getTechnologyOperationTemplateId())>0;
|
}
|
|
@Override
|
public boolean fullSave(Template operationTemplate) {
|
checkTemplateNo(operationTemplate);
|
baseMapper.insert(operationTemplate);
|
return true;
|
}
|
|
@Override
|
public boolean fullUpdate(Template operationTemplate) {
|
checkTemplateNo(operationTemplate);
|
baseMapper.updateById(operationTemplate);
|
return true;
|
}
|
|
private void checkTemplateNo(Template template) {
|
if (StringUtils.isBlank(template.getTemplateNo())) {
|
// 1. 自动生成编号
|
template.setTemplateNo(templateNumberGenerator.generateNumberWithPrefix(Template.DIGIT, Template.PREFIX, Template::getTemplateNo));
|
} else {
|
// 2.判断是否重复
|
int count = baseMapper.selectCount(Wrappers.<Template>query().lambda().eq(Template::getTemplateNo, template.getTemplateNo()).ne(Template::getId, template.getId()));
|
if (count > 0) {
|
throw new RuntimeException("存在重复的模板编号");
|
}
|
}
|
}
|
|
@Override
|
public boolean delete(Long id) {
|
baseMapper.deleteById(id);
|
paramJoinTemplateMapper.delete(Wrappers.<ParamJoinTemplate>lambdaQuery().eq(ParamJoinTemplate::getTechnologyOperationTemplateId, id));
|
return true;
|
}
|
|
@Override
|
public IPage<List<TemplateTypeRelation>> getOperationTemplateByType(Page page, QueryWrapper<Template> gen) {
|
return baseMapper.getOperationTemplateByType(page, gen);
|
}
|
|
@Override
|
public void uploadTemplate(HttpServletResponse response, String fileName) {
|
String name = FileEnums.getFileName(fileName);
|
InputStream ins = null;
|
try {
|
ins = new FileInputStream("D:/file/导入模板/" + name + ".xlsx");
|
response.setContentType("application/octet-stream; charset=UTF-8");
|
IoUtil.copy(ins, response.getOutputStream());
|
} catch (IOException e) {
|
e.printStackTrace();
|
} finally {
|
try {
|
assert ins != null;
|
ins.close();
|
} catch (IOException e) {
|
e.printStackTrace();
|
}
|
}
|
}
|
|
@Override
|
public List<ParamDTO> getLastParamById(ParamDTO paramDTO) {
|
return paramMapper.getLastParamById(paramDTO);
|
}
|
}
|