Compare commits

..

No commits in common. "04109205c8cdefd2801a7aca0db0f503892add37" and "8c564739af07fb7eda13e879af9f3a5a928980b2" have entirely different histories.

19 changed files with 95 additions and 281 deletions

View File

@ -4,6 +4,7 @@ import jakarta.validation.Valid;
import jakarta.validation.constraints.NotBlank;
import jakarta.validation.constraints.NotNull;
import lombok.Data;
import model.TextPosition;
import java.util.List;
@ -146,7 +147,7 @@ public class QmsInspectionStandardSaveQO {
/**
* 排序号
*/
private Integer sortNo = 0;
private Integer sortNo=0;
/**
* 检测项名称
@ -164,35 +165,15 @@ public class QmsInspectionStandardSaveQO {
*/
private String legend;
/**
* PDF信息
*/
private TextPosition pdfInfo;
/**
* 判定类型0直接判定1测量值
*/
@NotNull(message = "判定类型不能为空")
private Integer judgmentType;
/**
* PDF页码
*/
private Integer pdfPageNum;
/**
* PDF x轴起始位置
*/
private Float pdfX;
/**
* PDF y轴起始位置
*/
private Float pdfY;
/**
* PDF宽度
*/
private Float pdfWidth;
/**
* PDF高度
*/
private Float pdfHeight;
}
}

View File

@ -1,6 +1,7 @@
package com.nflg.qms.admin.pojo.vo;
import lombok.Data;
import model.TextPosition;
import java.time.LocalDateTime;
@ -35,36 +36,16 @@ public class QmsInspectionStandardItemContentVO {
*/
private String legend;
/**
* PDF信息
*/
private TextPosition pdfInfo;
/**
* 判定类型0直接判定1测量值
*/
private Integer judgmentType;
/**
* PDF页码
*/
private Integer pdfPageNum;
/**
* PDF x轴起始位置
*/
private Float pdfX;
/**
* PDF y轴起始位置
*/
private Float pdfY;
/**
* PDF宽度
*/
private Float pdfWidth;
/**
* PDF高度
*/
private Float pdfHeight;
/**
* 创建人姓名
*/

View File

@ -187,7 +187,6 @@ public class IncomingInspectionTaskControllerService {
// 7. 构建并保存来料检测任务
QmsIncomingInspectionTask task = new QmsIncomingInspectionTask()
.setRequestNo(request.getRequestNo())
.setTaskNo(taskNo)
.setMaterialId(material.getId())
.setInspectionStandardId(standard.getId())
@ -312,7 +311,6 @@ public class IncomingInspectionTaskControllerService {
// 7. 构建并保存库存检测任务存入来料检测任务表dataType=1
QmsIncomingInspectionTask task = new QmsIncomingInspectionTask()
.setRequestNo(request.getRequestNo())
.setTaskNo(taskNo)
.setMaterialId(material.getId())
.setInspectionStandardId(standard.getId())

View File

@ -3,6 +3,7 @@ package com.nflg.qms.admin.service;
import cn.hutool.core.collection.CollectionUtil;
import cn.hutool.core.convert.Convert;
import cn.hutool.core.util.StrUtil;
import cn.hutool.json.JSONUtil;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.nflg.qms.admin.pojo.qo.QmsPdfExtractRegionQO;
@ -25,6 +26,7 @@ import com.nflg.wms.repository.service.*;
import jakarta.annotation.Resource;
import lombok.extern.slf4j.Slf4j;
import model.DimensionResult;
import model.TextPosition;
import org.springframework.stereotype.Component;
import org.springframework.transaction.annotation.Transactional;
import service.PdfExtractionService;
@ -302,11 +304,9 @@ public class QmsInspectionStandardControllerService {
vo.setName(content.getName());
vo.setTestStandard(content.getTestStandard());
vo.setLegend(content.getLegend());
vo.setPdfPageNum(content.getPdfPageNum());
vo.setPdfX(content.getPdfX());
vo.setPdfY(content.getPdfY());
vo.setPdfWidth(content.getPdfWidth());
vo.setPdfHeight(content.getPdfHeight());
if (StrUtil.isNotBlank(content.getPdfInfo())) {
vo.setPdfInfo(JSONUtil.toBean(content.getPdfInfo(), TextPosition.class));
}
vo.setJudgmentType(content.getJudgmentType());
vo.setCreateUserName(content.getCreateUserName());
vo.setCreateTime(content.getCreateTime());
@ -681,14 +681,11 @@ public class QmsInspectionStandardControllerService {
if (qo.getLegend() != null) {
content.setLegend(qo.getLegend());
}
if (qo.getPdfInfo() != null) {
content.setPdfInfo(JSONUtil.toJsonStr(qo.getPdfInfo()));
}
content.setJudgmentType(qo.getJudgmentType());
content.setPdfPageNum(qo.getPdfPageNum());
content.setPdfX(qo.getPdfX());
content.setPdfY(qo.getPdfY());
content.setPdfWidth(qo.getPdfWidth());
content.setPdfHeight(qo.getPdfHeight());
content.setUpdateUserId(userId);
content.setUpdateUserName(userName);
content.setUpdateTime(now);

View File

@ -1,5 +1,7 @@
package com.nflg.qms.admin.service;
import cn.hutool.core.util.StrUtil;
import cn.hutool.json.JSONUtil;
import com.nflg.wms.common.exception.NflgException;
import com.nflg.qms.admin.pojo.vo.QmsInspectionStandardItemContentVO;
import com.nflg.wms.repository.entity.QmsInspectionStandardItem;
@ -8,6 +10,7 @@ import com.nflg.wms.repository.service.IQmsInspectionStandardItemContentService;
import com.nflg.wms.repository.service.IQmsInspectionStandardItemService;
import jakarta.annotation.Resource;
import lombok.extern.slf4j.Slf4j;
import model.TextPosition;
import org.springframework.stereotype.Component;
import java.util.List;
@ -59,11 +62,9 @@ public class QmsInspectionStandardItemControllerService {
vo.setName(content.getName());
vo.setTestStandard(content.getTestStandard());
vo.setLegend(content.getLegend());
vo.setPdfPageNum(content.getPdfPageNum());
vo.setPdfX(content.getPdfX());
vo.setPdfY(content.getPdfY());
vo.setPdfWidth(content.getPdfWidth());
vo.setPdfHeight(content.getPdfHeight());
if (StrUtil.isNotBlank(content.getPdfInfo())) {
vo.setPdfInfo(JSONUtil.toBean(content.getPdfInfo(), TextPosition.class));
}
vo.setJudgmentType(content.getJudgmentType());
vo.setCreateUserName(content.getCreateUserName());
vo.setCreateTime(content.getCreateTime());

View File

@ -78,11 +78,6 @@ public class QmsQcMaterialControllerService {
* 分页查询质检物料
*/
public PageData<QmsQcMaterialVO> search(QmsQcMaterialSearchQO request) {
// 若传入了物料类别编码展开为包含当前类别及所有子孙类别的编码列表
if (StrUtil.isNotBlank(request.getMaterialCategoryCode())) {
request.setMaterialCategoryCodes(expandCategoryCodes(request.getMaterialCategoryCode()));
}
IPage<QmsQcMaterialVO> page = qcMaterialMapper.searchPage(
request, new Page<>(request.getPage(), request.getPageSize()));
@ -94,41 +89,6 @@ public class QmsQcMaterialControllerService {
return result;
}
/**
* 展开物料类别编码查询指定编码对应的类别及其所有子孙类别的编码列表一次查询无递归
* <p>
* parentTree 存储完整祖先路径ltree 格式 0.A.B.C子孙节点满足
* parentTree = fullPath OR parentTree LIKE 'fullPath.%'
* </p>
*/
private List<String> expandCategoryCodes(String categoryCode) {
QmsQcMaterialCategory category = qcMaterialCategoryService.lambdaQuery()
.eq(QmsQcMaterialCategory::getCategoryCode, categoryCode)
.one();
if (category == null) {
// 类别不存在原样返回Mapper IN 条件查不到数据
return List.of(categoryCode);
}
// 构建当前节点完整路径parentTree.id parentTree 为空则直接取 id
String fullPath = StrUtil.isBlank(category.getParentTree())
? String.valueOf(category.getId())
: category.getParentTree();
// 一次查询自身 + 直接子节点parentTree=fullPath+ 孙级及更深parentTree LIKE 'fullPath.%'
// parent_tree ltree 类型需显式转为 text 才能与 varchar 比较
return qcMaterialCategoryService.lambdaQuery()
.eq(QmsQcMaterialCategory::getCategoryCode, categoryCode)
.or().apply("parent_tree::text = {0}", fullPath)
.or().apply("parent_tree::text LIKE {0}", fullPath + ".%")
.list()
.stream()
.map(QmsQcMaterialCategory::getCategoryCode)
.filter(Objects::nonNull)
.distinct()
.collect(Collectors.toList());
}
/**
* 新增质检物料
*/
@ -415,10 +375,6 @@ public class QmsQcMaterialControllerService {
* 导出质检物料不分页
*/
public void exportSearch(HttpServletResponse response, QmsQcMaterialSearchQO request) throws IOException {
// 导出同样支持子孙类别展开
if (StrUtil.isNotBlank(request.getMaterialCategoryCode())) {
request.setMaterialCategoryCodes(expandCategoryCodes(request.getMaterialCategoryCode()));
}
EecExcelUtil.export("质检物料", "质检物料", qcMaterialMapper.searchAll(request), response);
}

View File

@ -104,13 +104,12 @@ public class WmsIncomingInspectionTaskCallbackService {
private void inventory(QmsIncomingInspectionTaskVO taskVO, Short processingResult) {
WmsInventoryInspectionTaskCallbackQO qo = new WmsInventoryInspectionTaskCallbackQO()
.setTaskNo(taskVO.getTaskNo())
.setRequestNo(taskVO.getRequestNo())
.setMaterialNo(taskVO.getMaterialNo())
.setFactory(taskVO.getFactory())
.setWarehouse(taskVO.getWarehouse())
.setStorageLocation(taskVO.getStorageLocation())
.setStorageDays(taskVO.getStorageDays())
.setDetectionQty(taskVO.getDetectionQty())
.setInspectionQty(taskVO.getInspectionQty())
.setQualifiedQty(taskVO.getQualifiedQty())
.setUnqualifiedQty(taskVO.getUnqualifiedQty())
.setInspectionResult(taskVO.getInspectionResult())

View File

@ -1,6 +1,5 @@
package extraction;
import lombok.Getter;
import model.TextElement;
import org.apache.pdfbox.pdmodel.PDPage;
import org.apache.pdfbox.pdmodel.common.PDRectangle;
@ -12,7 +11,6 @@ import java.util.ArrayList;
import java.util.List;
public class PositionedTextStripper extends PDFTextStripper {
@Getter
private final List<TextElement> elements = new ArrayList<>();
private int currentPage = 0;
private float currentPageWidth = 0;
@ -55,4 +53,7 @@ public class PositionedTextStripper extends PDFTextStripper {
super.writeString(text, textPositions);
}
public List<TextElement> getElements() {
return elements;
}
}

View File

@ -0,0 +1,47 @@
package model;
import lombok.Data;
@Data
public class TextPosition {
/**
* 页码
*/
private int pageNum;
/**
* x轴起始位置
*/
private float x;
/**
* y轴起始位置
*/
private float y;
/**
* 宽度
*/
private float width;
/**
* 高度
*/
private float height;
/**
* 页宽
*/
private float pageWidth;
/**
* 页高
*/
private float pageHeight;
/**
* 序号
*/
private int sortOrder;
}

View File

@ -11,12 +11,6 @@ import lombok.Data;
@Data
public class ExternalIncomingInspectionApplyQO {
/**
* 请求单号第三方唯一编号
*/
@NotBlank(message = "请求单号不能为空")
private String requestNo;
/**
* 物料编号必填
*/

View File

@ -11,12 +11,6 @@ import lombok.Data;
@Data
public class ExternalInventoryInspectionApplyQO {
/**
* 请求单号第三方唯一编号
*/
@NotBlank(message = "请求单号不能为空")
private String requestNo;
/**
* 物料编号必填
*/

View File

@ -2,8 +2,6 @@ package com.nflg.wms.common.pojo.qo;
import lombok.Data;
import java.util.List;
/**
* 查询质检物料列表 请求参数分页
*/
@ -15,11 +13,6 @@ public class QmsQcMaterialSearchQO extends PageQO {
*/
private String materialCategoryCode;
/**
* 物料类别编码列表内部使用 Service 层自动填充包含当前类别及其所有子孙类别编码
*/
private List<String> materialCategoryCodes;
/**
* 物料编号模糊匹配
*/
@ -34,15 +27,4 @@ public class QmsQcMaterialSearchQO extends PageQO {
* 物料名称模糊匹配
*/
private String materialName;
/**
* 排序字段对应 QmsQcMaterialVO 中的字段名 materialNocreateTime
* 为空时默认按物料编号倒序
*/
private String sortField;
/**
* 排序类型asc=升序desc=降序默认 desc
*/
private String sortOrder;
}

View File

@ -1,6 +1,5 @@
package com.nflg.wms.common.pojo.qo;
import jakarta.validation.constraints.NotBlank;
import lombok.Data;
import lombok.experimental.Accessors;
@ -15,11 +14,6 @@ public class WmsInventoryInspectionTaskCallbackQO {
*/
private String taskNo;
/**
* 请求单号第三方唯一编号
*/
private String requestNo;
/**
* 物料编号
*/
@ -46,9 +40,9 @@ public class WmsInventoryInspectionTaskCallbackQO {
private Integer storageDays;
/**
* 数量
* 检数量
*/
private Integer detectionQty;
private Integer inspectionQty;
/**
* 合格数量

View File

@ -17,11 +17,6 @@ public class QmsIncomingInspectionTaskVO {
*/
private String taskNo;
/**
* 请求单号第三方唯一编号
*/
private String requestNo;
/**
* 物料id
*/

View File

@ -37,11 +37,6 @@ public class QmsIncomingInspectionTask implements Serializable {
*/
private String taskNo;
/**
* 请求单号第三方唯一编号
*/
private String requestNo;
/**
* 物料id关联质检物料表
*/

View File

@ -51,36 +51,16 @@ public class QmsInspectionStandardItemContent implements Serializable {
*/
private String legend;
/**
* PDF信息
*/
private String pdfInfo;
/**
* 判定类型0直接判定1测量值
*/
private Integer judgmentType;
/**
* PDF页码
*/
private Integer pdfPageNum;
/**
* PDF x轴起始位置
*/
private Float pdfX;
/**
* PDF y轴起始位置
*/
private Float pdfY;
/**
* PDF宽度
*/
private Float pdfWidth;
/**
* PDF高度
*/
private Float pdfHeight;
/**
* 创建人ID
*/

View File

@ -50,9 +50,7 @@ public class DepartmentServiceImpl extends ServiceImpl<DepartmentMapper, Departm
.setParentId(request.getParentId())
.setEnable(request.getEnable())
.setCreateBy(UserUtil.getUserName())
.setCreateTime(LocalDateTime.now())
.setHeadUserId(request.getHeadUserId())
.setHeadUserName(request.getHeadUserName());
.setCreateTime(LocalDateTime.now());
save(department);
auditLogService.addInsert(Department.class, department, UserUtil.getUserName());
}
@ -79,9 +77,7 @@ public class DepartmentServiceImpl extends ServiceImpl<DepartmentMapper, Departm
.setEnable(request.getEnable())
.setCreateBy(dept1.getCreateBy())
.setCreateTime(dept1.getCreateTime())
.setSourceId(request.getNo())
.setHeadUserId(request.getHeadUserId())
.setHeadUserName(request.getHeadUserName());
.setSourceId(request.getNo());
//Department dept2 = BeanUtil.copy(dept1, Department.class);

View File

@ -6,7 +6,6 @@
SELECT
t.id,
t.task_no,
t.check_no,
t.material_id,
m.material_no,
m.material_desc,
@ -109,7 +108,6 @@
SELECT
t.id,
t.task_no,
t.check_no,
t.material_id,
m.material_no,
m.material_desc,
@ -182,7 +180,6 @@
<select id="getDetail" resultType="com.nflg.wms.common.pojo.vo.QmsIncomingInspectionTaskVO">
SELECT t.id,
t.task_no,
t.check_no,
t.material_id,
m.material_no,
m.material_desc,

View File

@ -27,17 +27,9 @@
update_time
FROM qms_qc_material
<where>
<choose>
<when test="request.materialCategoryCodes != null and !request.materialCategoryCodes.isEmpty()">
AND material_category_code IN
<foreach collection="request.materialCategoryCodes" item="code" open="(" separator="," close=")">
#{code}
</foreach>
</when>
<when test="request.materialCategoryCode != null and request.materialCategoryCode != ''">
<if test="request.materialCategoryCode != null and request.materialCategoryCode != ''">
AND material_category_code = #{request.materialCategoryCode}
</when>
</choose>
</if>
<if test="request.materialNo != null and request.materialNo != ''">
AND material_no ilike concat('%', #{request.materialNo}, '%')
</if>
@ -48,36 +40,7 @@
AND material_name ilike concat('%', #{request.materialName}, '%')
</if>
</where>
ORDER BY
<choose>
<when test="request.sortField != null and request.sortField != ''">
<choose>
<when test="request.sortField == 'id'">id</when>
<when test="request.sortField == 'materialNo'">material_no</when>
<when test="request.sortField == 'materialDesc'">material_desc</when>
<when test="request.sortField == 'materialDescIsUpgrade'">material_desc_is_upgrade</when>
<when test="request.sortField == 'materialCategoryCode'">material_category_code</when>
<when test="request.sortField == 'materialCategoryCodePathName'">material_category_code_path_name</when>
<when test="request.sortField == 'drawingNo'">drawing_no</when>
<when test="request.sortField == 'drawingNoVer'">drawing_no_ver</when>
<when test="request.sortField == 'materialName'">material_name</when>
<when test="request.sortField == 'materialTexture'">material_texture</when>
<when test="request.sortField == 'materialSpecifications'">material_specifications</when>
<when test="request.sortField == 'isStandardMaintained'">is_standard_maintained</when>
<when test="request.sortField == 'createdType'">created_type</when>
<when test="request.sortField == 'createByName'">create_by_name</when>
<when test="request.sortField == 'createTime'">create_time</when>
<when test="request.sortField == 'updateByName'">update_by_name</when>
<when test="request.sortField == 'updateTime'">update_time</when>
<otherwise>material_no</otherwise>
</choose>
<choose>
<when test="request.sortOrder != null and request.sortOrder.equalsIgnoreCase('asc')">ASC</when>
<otherwise>DESC</otherwise>
</choose>
</when>
<otherwise>material_no DESC</otherwise>
</choose>
ORDER BY id DESC
</select>
<!--
@ -102,17 +65,9 @@
TO_CHAR(create_time, 'YYYY-MM-DD HH24:MI:SS') AS create_time
FROM qms_qc_material
<where>
<choose>
<when test="request.materialCategoryCodes != null and !request.materialCategoryCodes.isEmpty()">
AND material_category_code IN
<foreach collection="request.materialCategoryCodes" item="code" open="(" separator="," close=")">
#{code}
</foreach>
</when>
<when test="request.materialCategoryCode != null and request.materialCategoryCode != ''">
<if test="request.materialCategoryCode != null and request.materialCategoryCode != ''">
AND material_category_code = #{request.materialCategoryCode}
</when>
</choose>
</if>
<if test="request.materialNo != null and request.materialNo != ''">
AND material_no ilike concat('%', #{request.materialNo}, '%')
</if>
@ -123,36 +78,7 @@
AND material_name ilike concat('%', #{request.materialName}, '%')
</if>
</where>
ORDER BY
<choose>
<when test="request.sortField != null and request.sortField != ''">
<choose>
<when test="request.sortField == 'id'">id</when>
<when test="request.sortField == 'materialNo'">material_no</when>
<when test="request.sortField == 'materialDesc'">material_desc</when>
<when test="request.sortField == 'materialDescIsUpgrade'">material_desc_is_upgrade</when>
<when test="request.sortField == 'materialCategoryCode'">material_category_code</when>
<when test="request.sortField == 'materialCategoryCodePathName'">material_category_code_path_name</when>
<when test="request.sortField == 'drawingNo'">drawing_no</when>
<when test="request.sortField == 'drawingNoVer'">drawing_no_ver</when>
<when test="request.sortField == 'materialName'">material_name</when>
<when test="request.sortField == 'materialTexture'">material_texture</when>
<when test="request.sortField == 'materialSpecifications'">material_specifications</when>
<when test="request.sortField == 'isStandardMaintained'">is_standard_maintained</when>
<when test="request.sortField == 'createdType'">created_type</when>
<when test="request.sortField == 'createByName'">create_by_name</when>
<when test="request.sortField == 'createTime'">create_time</when>
<when test="request.sortField == 'updateByName'">update_by_name</when>
<when test="request.sortField == 'updateTime'">update_time</when>
<otherwise>material_no</otherwise>
</choose>
<choose>
<when test="request.sortOrder != null and request.sortOrder.equalsIgnoreCase('asc')">ASC</when>
<otherwise>DESC</otherwise>
</choose>
</when>
<otherwise>material_no DESC</otherwise>
</choose>
ORDER BY id DESC
</select>
</mapper>