From 1de6b39bfe3967916dcab8122be0d69fbaba8cca Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期五, 30 五月 2025 17:29:06 +0800
Subject: [PATCH] Merge branch 'devlop' of http://47.97.1.152:5880/r/wms-master into devlop

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/DeviceSiteServiceImpl.java |   55 ++++++++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 42 insertions(+), 13 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/DeviceSiteServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/DeviceSiteServiceImpl.java
index 9328ef1..467a9e9 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/DeviceSiteServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/DeviceSiteServiceImpl.java
@@ -3,11 +3,14 @@
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.vincent.rsf.framework.exception.CoolException;
 import com.vincent.rsf.server.manager.controller.params.DeviceSiteParame;
+import com.vincent.rsf.server.manager.entity.BasStation;
 import com.vincent.rsf.server.manager.mapper.DeviceSiteMapper;
 import com.vincent.rsf.server.manager.entity.DeviceSite;
+import com.vincent.rsf.server.manager.service.BasStationService;
 import com.vincent.rsf.server.manager.service.DeviceSiteService;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
 import java.util.ArrayList;
@@ -18,6 +21,10 @@
 @Service("deviceSiteService")
 public class DeviceSiteServiceImpl extends ServiceImpl<DeviceSiteMapper, DeviceSite> implements DeviceSiteService {
 
+    @Autowired
+    private BasStationService basStationService;
+
+
     /**
      * 鍒濆鍖栫珯鐐�
      * @param param
@@ -26,30 +33,52 @@
     @Override
     public boolean initSites(DeviceSiteParame param) {
         if (param.getFlagInit() == 1) {
-            if (!this.remove(new LambdaQueryWrapper<>())) {
-                throw new CoolException("鍒濆鍖栧け璐ワ細 鍒犻櫎绔欑偣澶辫触锛侊紒");
+            List<DeviceSite> list = this.list(new LambdaQueryWrapper<DeviceSite>().select(DeviceSite::getId).last("limit 1"));
+            if (!list.isEmpty()) {
+                if (!this.remove(new LambdaQueryWrapper<>())) {
+                    throw new CoolException("鍒濆鍖栧け璐ワ細 鍒犻櫎绔欑偣澶辫触锛侊紒");
+                }
             }
         }
-        if (Objects.isNull(param.getDeviceSites()) || param.getDeviceSites().isEmpty()) {
+        if (Objects.isNull(param.getDeviceSites()) || StringUtils.isBlank(param.getDeviceSites())) {
             throw new CoolException("鍒濆鍖栧け璐ワ細 璁惧浣滀笟绔欑偣涓嶈兘涓虹┖锛侊紒");
         }
-        if (Objects.isNull(param.getSites()) || param.getSites().isEmpty()) {
+        if (Objects.isNull(param.getSite()) || StringUtils.isBlank(param.getSite())) {
             throw new CoolException("鍒濆鍖栧け璐�: 浣滀笟绔欑偣涓嶈兘涓虹┖锛侊紒");
         }
         if (Objects.isNull(param.getTypeIds()) || param.getTypeIds().isEmpty()) {
             throw new CoolException("鍒濆鍖栧け璐ワ細 浣滀笟绫诲瀷涓嶈兘涓虹┖锛侊紒");
         }
+        if (Objects.isNull(param.getTarget()) || param.getTarget().isEmpty()) {
+            throw new CoolException("鍒濆鍖栧け璐ワ細 鐩爣绔欑偣涓嶈兘涓虹┖锛侊紒");
+        }
+        List<String> sites = Arrays.asList(StringUtils.split(param.getSite(), ","));
+        List<String> dvSites = Arrays.asList(StringUtils.split(param.getDeviceSites(), ","));
+        List<String> targets = Arrays.asList(StringUtils.split(param.getTarget(), ","));
         List<DeviceSite> deviceSites =  new ArrayList<>();
-        for (String site : param.getSites()) {
-            for (String deviceSite : param.getDeviceSites()) {
+        for (String site : sites) {
+            BasStation basStation = basStationService.getOne(new LambdaQueryWrapper<BasStation>().eq(BasStation::getStationName, site));
+            if (null == basStation) {
+                throw new CoolException("鍒濆鍖栧け璐ワ細 绔欑偣鏈壘鍒帮紒锛�");
+            }
+            for (String deviceSite : dvSites) {
+                BasStation basStation2 = basStationService.getOne(new LambdaQueryWrapper<BasStation>().eq(BasStation::getStationName, deviceSite));
+                if (null == basStation2) {
+                    throw new CoolException("鍒濆鍖栧け璐ワ細 浣滀笟绔欑偣鏈壘鍒帮紒锛�");
+                }
                 for (Long id : param.getTypeIds()) {
-                    DeviceSite site1 = new DeviceSite();
-                    site1.setType(id + "")
-                            .setSite(site)
-                            .setDevice(param.getDeviceType())
-                            .setDeviceSite(deviceSite)
-                            .setDeviceCode(param.getDeviceCode());
-                    deviceSites.add(site1);
+                    for (String target : targets) {
+                        DeviceSite site1 = new DeviceSite();
+                        site1.setType(id + "")
+                                .setSite(site)
+                                .setDevice(param.getDeviceType())
+                                .setDeviceSite(deviceSite)
+                                .setTarget(target)
+                                .setDeviceCode(param.getDeviceCode())
+                                .setChannel(param.getChannel())
+                                ;
+                        deviceSites.add(site1);
+                    }
                 }
             }
         }

--
Gitblit v1.9.1