From b5ef65d0103a71dc7af2b9be6d2ac43aca5bb726 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期二, 27 八月 2024 08:59:57 +0800
Subject: [PATCH] 代码提交 bug解决

---
 ruoyi-modules/ruoyi-management/src/main/java/com/ruoyi/management/service/impl/SlEquipmentServiceImpl.java |   76 ++++++++++++++++++++++++++++++++++++-
 1 files changed, 73 insertions(+), 3 deletions(-)

diff --git a/ruoyi-modules/ruoyi-management/src/main/java/com/ruoyi/management/service/impl/SlEquipmentServiceImpl.java b/ruoyi-modules/ruoyi-management/src/main/java/com/ruoyi/management/service/impl/SlEquipmentServiceImpl.java
index a20514e..b55157a 100644
--- a/ruoyi-modules/ruoyi-management/src/main/java/com/ruoyi/management/service/impl/SlEquipmentServiceImpl.java
+++ b/ruoyi-modules/ruoyi-management/src/main/java/com/ruoyi/management/service/impl/SlEquipmentServiceImpl.java
@@ -1,9 +1,11 @@
 package com.ruoyi.management.service.impl;
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.ruoyi.common.core.utils.page.PageDTO;
+import com.ruoyi.common.core.web.domain.AjaxResult;
 import com.ruoyi.management.domain.SlEquipment;
 import com.ruoyi.management.domain.SlGoodsMaterials;
 import com.ruoyi.management.domain.SlStoreManagement;
@@ -15,10 +17,11 @@
 import com.ruoyi.management.mapper.SlStoreManagementMapper;
 import com.ruoyi.management.service.SlEquipmentService;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.system.api.domain.SeBei;
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
-import java.util.List;
+import java.util.*;
 
 /**
  * <p>
@@ -41,7 +44,7 @@
         if(slEquipmentQuery.getEquipmentName()!=null&&slEquipmentQuery.getEquipmentName()!=""){
             wrapper.like(SlEquipment::getEquipmentName,slEquipmentQuery.getEquipmentName());
         }
-        if(slEquipmentQuery.getEquipmentName()!=null&&slEquipmentQuery.getType()!=0){
+        if(slEquipmentQuery.getType()!=null&&slEquipmentQuery.getType()!=0){
         wrapper.eq(SlEquipment::getType,slEquipmentQuery.getType());
         }
         wrapper.eq( SlEquipment::getDelFlag,0);
@@ -65,8 +68,15 @@
     }
 
     @Override
-    public void addSlEquipment(SlEquipmentDTO slEquipmentDTO) {
+    public AjaxResult addSlEquipment(SlEquipmentDTO slEquipmentDTO) {
+
         if (slEquipmentDTO.getId()==null){
+            List<SlEquipment> list = this.list(new QueryWrapper<SlEquipment>()
+                    .eq("type", slEquipmentDTO.getType())
+                    .eq("equipment_num", slEquipmentDTO.getEquipmentNum()));
+            if (!list.isEmpty()){
+                return AjaxResult.error("当前设备已存在相同设备编号");
+            }
             SlEquipment slEquipment=new SlEquipment();
             slEquipment.setEquipmentName(slEquipmentDTO.getEquipmentName());
             slEquipment.setEquipmentNum(slEquipmentDTO.getEquipmentNum());
@@ -75,6 +85,13 @@
             this.save(slEquipment);
         }else{
             SlEquipment byId = this.getById(slEquipmentDTO.getId());
+            List<SlEquipment> list = this.list(new QueryWrapper<SlEquipment>()
+                    .eq("type", slEquipmentDTO.getType())
+                    .ne("id",slEquipmentDTO.getId())
+                    .eq("equipment_num", slEquipmentDTO.getEquipmentNum()));
+            if (!list.isEmpty()){
+                return AjaxResult.error("当前设备已存在相同设备编号");
+            }
             if (slEquipmentDTO.getEquipmentName()!=null){
                 byId.setEquipmentName(slEquipmentDTO.getEquipmentName());
             }
@@ -89,6 +106,7 @@
             }
             this.updateById(byId);
         }
+        return AjaxResult.success();
     }
 
     @Override
@@ -102,6 +120,7 @@
 
         SlStoreManagement slStoreManagement = slStoreManagementMapper.selectById(byId.getManagementId());
         slEquipmentVO.setCountyCode(slStoreManagement.getCountyCode());
+        slEquipmentVO.setStoreManagementName(slStoreManagement.getStoreManagementName());
         slEquipmentVO.setProvinceName(slStoreManagement.getProvinceName());
         slEquipmentVO.setProvinceCode(slStoreManagement.getProvinceCode());
         slEquipmentVO.setCountyName(slStoreManagement.getCountyName());
@@ -112,4 +131,55 @@
 
         return slEquipmentVO;
     }
+
+    @Override
+    public Integer getequipmente(SeBei seBei) {
+        LambdaQueryWrapper< SlStoreManagement> wrapper= Wrappers.lambdaQuery();
+
+        List<Long> arr=new ArrayList<>();
+        wrapper.eq(SlStoreManagement::getDelFlag,0);
+        List<SlStoreManagement> page = slStoreManagementMapper.selectList(wrapper);
+        for (SlStoreManagement a:page){
+            List<String> list = Arrays.asList(a.getAdministratorId().split(","));
+            if (list.contains(seBei.getUserId().toString())){
+                arr.add(a.getId());
+            }
+        }
+        LambdaQueryWrapper< SlStoreManagement> wrapper1= Wrappers.lambdaQuery();
+        wrapper1.eq(SlStoreManagement::getDelFlag,0);
+        List<SlStoreManagement> page1 = slStoreManagementMapper.selectList(wrapper1);
+        for (SlStoreManagement a1:page1){
+            List<String> list = Arrays.asList(a1.getCompetentId().split(","));
+            if (list.contains(seBei.getUserId().toString())){
+                arr.add(a1.getId());
+            }
+        }
+        LambdaQueryWrapper< SlStoreManagement> wrapper2= Wrappers.lambdaQuery();
+        wrapper2.eq(SlStoreManagement::getDelFlag,0);
+        List<SlStoreManagement> page2 = slStoreManagementMapper.selectList(wrapper2);
+        for (SlStoreManagement a2:page2){
+            List<String> list = Arrays.asList(a2.getDirectorId().split(","));
+            if (list.contains(seBei.getUserId().toString())){
+                arr.add(a2.getId());
+            }
+        }
+        Set<Long> set = new HashSet<>(arr);
+        arr.clear();
+        arr.addAll(set);
+
+        int i=1;
+        for (Long arr1:arr){
+            LambdaQueryWrapper< SlEquipment> wrapper3= Wrappers.lambdaQuery();
+                wrapper3.eq(SlEquipment::getManagementId,arr1);
+                wrapper3.eq(SlEquipment::getEquipmentNum,seBei.getSebei());
+            wrapper3.eq( SlEquipment::getDelFlag,0);
+            List<SlEquipment> page3 = this.list( wrapper3);
+            if (page3.size()>0){
+                i=2;
+                break;
+            }
+
+        }
+      return i;
+    }
 }

--
Gitblit v1.7.1