From bb80ead86615da40c73ed60a04944461e52929e7 Mon Sep 17 00:00:00 2001
From: gongchunyi <deslre0381@gmail.com>
Date: 星期五, 20 三月 2026 16:19:25 +0800
Subject: [PATCH] fix: 工艺路线查询未携带状态
---
src/main/java/com/ruoyi/production/service/impl/ProductionOrderRouteItemParamServiceImpl.java | 122 ++++++++++++++++++++++++++++++++++++++++
1 files changed, 122 insertions(+), 0 deletions(-)
diff --git a/src/main/java/com/ruoyi/production/service/impl/ProductionOrderRouteItemParamServiceImpl.java b/src/main/java/com/ruoyi/production/service/impl/ProductionOrderRouteItemParamServiceImpl.java
new file mode 100644
index 0000000..8cb5947
--- /dev/null
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductionOrderRouteItemParamServiceImpl.java
@@ -0,0 +1,122 @@
+package com.ruoyi.production.service.impl;
+
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.basic.pojo.BaseParam;
+import com.ruoyi.basic.service.BaseParamService;
+import com.ruoyi.common.exception.ServiceException;
+import com.ruoyi.common.utils.SecurityUtils;
+import com.ruoyi.production.dto.ProductionOrderRouteItemParamDto;
+import com.ruoyi.production.mapper.ProductionOrderRouteItemParamMapper;
+import com.ruoyi.production.pojo.ProductionOrderRouteItemParam;
+import com.ruoyi.production.service.IProductionOrderRouteItemParamService;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.time.LocalDateTime;
+import java.util.List;
+import java.util.stream.Collectors;
+
+/**
+ * <p>
+ * 鐢熶骇璁㈠崟缁戝畾鐨勫伐鑹鸿矾绾垮伐搴�--鍙傛暟琛� 鏈嶅姟瀹炵幇绫�
+ * </p>
+ *
+ * @author deslrey
+ * @since 2026-03-20
+ */
+@Slf4j
+@Service
+public class ProductionOrderRouteItemParamServiceImpl extends ServiceImpl<ProductionOrderRouteItemParamMapper, ProductionOrderRouteItemParam> implements IProductionOrderRouteItemParamService {
+
+ @Autowired
+ private BaseParamService baseParamService;
+
+ @Override
+ public List<ProductionOrderRouteItemParamDto> routeItemParamList(Long orderId, Long routeItemId) {
+ List<ProductionOrderRouteItemParam> list = list(new LambdaQueryWrapper<ProductionOrderRouteItemParam>()
+ .eq(ProductionOrderRouteItemParam::getOrderId, orderId)
+ .eq(ProductionOrderRouteItemParam::getRouteItemId, routeItemId)
+ .orderByAsc(ProductionOrderRouteItemParam::getSort));
+
+ return list.stream().map(item -> {
+ ProductionOrderRouteItemParamDto dto = new ProductionOrderRouteItemParamDto();
+ BeanUtils.copyProperties(item, dto);
+ return dto;
+ }).collect(Collectors.toList());
+ }
+
+ @Override
+ @Transactional(rollbackFor = Exception.class)
+ public void addRouteItemParam(ProductionOrderRouteItemParamDto dto) {
+ if (dto == null) {
+ throw new ServiceException("鏂板鏁版嵁涓嶈兘涓虹┖");
+ }
+ if (dto.getOrderId() == null) {
+ throw new ServiceException("鐢熶骇璁㈠崟ID涓嶈兘涓虹┖");
+ }
+ if (dto.getRouteItemId() == null) {
+ throw new ServiceException("宸ヨ壓璺嚎鏄庣粏ID涓嶈兘涓虹┖");
+ }
+ Long tenantId = SecurityUtils.getLoginUser().getTenantId();
+
+ BaseParam baseParam = baseParamService.getById(dto.getParamId());
+ if (baseParam == null) {
+ throw new ServiceException("鏂板鍙傛暟涓嶅瓨鍦�");
+ }
+
+ ProductionOrderRouteItemParam entity = new ProductionOrderRouteItemParam();
+ BeanUtils.copyProperties(dto, entity);
+ entity.setId(null);
+ entity.setOrderId(dto.getOrderId());
+ entity.setRouteItemId(dto.getRouteItemId());
+ entity.setIsRequired(dto.getIsRequired());
+ // 鍙栧綋鍓嶈鍗�+璺嚎鏄庣粏涓嬫渶澶� sort + 1
+ ProductionOrderRouteItemParam maxSortItem = getOne(new LambdaQueryWrapper<ProductionOrderRouteItemParam>()
+ .select(ProductionOrderRouteItemParam::getSort)
+ .eq(ProductionOrderRouteItemParam::getOrderId, dto.getOrderId())
+ .eq(ProductionOrderRouteItemParam::getRouteItemId, dto.getRouteItemId())
+ .orderByDesc(ProductionOrderRouteItemParam::getSort)
+ .last("limit 1"));
+ entity.setSort(maxSortItem != null && maxSortItem.getSort() != null ? maxSortItem.getSort() + 1 : 1);
+ entity.setParamKey(baseParam.getParamKey());
+ entity.setParamName(baseParam.getParamName());
+ entity.setParamFormat(baseParam.getParamFormat());
+ entity.setParamType(baseParam.getParamType());
+ entity.setValueMode(baseParam.getValueMode());
+ entity.setUnit(baseParam.getUnit());
+ entity.setRemark(baseParam.getRemark());
+ entity.setTenantId(tenantId);
+ entity.setCreateTime(LocalDateTime.now());
+ save(entity);
+ }
+
+ @Override
+ public void updateRouteItemParam(ProductionOrderRouteItemParamDto dto) {
+ if (dto == null || dto.getId() == null) {
+ throw new ServiceException("鏇存柊鏁版嵁鎴朓D涓嶈兘涓虹┖");
+ }
+ if (getById(dto.getId()) == null) {
+ throw new ServiceException("鏁版嵁涓嶅瓨鍦�");
+ }
+ ProductionOrderRouteItemParam entity = new ProductionOrderRouteItemParam();
+ BeanUtils.copyProperties(dto, entity);
+ entity.setUpdateTime(LocalDateTime.now());
+ updateById(entity);
+ }
+
+ @Override
+ @Transactional(rollbackFor = Exception.class)
+ public void deleteRouteItemParam(Long id) {
+ if (id == null) {
+ throw new ServiceException("ID涓嶈兘涓虹┖");
+ }
+ if (getById(id) == null) {
+ throw new ServiceException("鏁版嵁涓嶅瓨鍦�");
+ }
+ removeById(id);
+ }
+}
--
Gitblit v1.9.3