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