From 0916bb4ea987c0599b6af6bb8dd251a071770e05 Mon Sep 17 00:00:00 2001
From: pang.jiabao <pang_jiabao@163.com>
Date: 星期四, 23 十月 2025 14:32:15 +0800
Subject: [PATCH] 通用下拉选择框值从视图获取

---
 src/main/java/com/zy/asrs/service/impl/PlaServiceImpl.java |   10 +++
 src/main/java/com/zy/asrs/service/PlaService.java          |    3 +
 src/main/java/com/zy/asrs/controller/PlaController.java    |   23 +++++++
 src/main/webapp/views/pla/plaDetl.html                     |   11 +++
 src/main/webapp/static/js/pla/plaDetl.js                   |   27 +++++++++
 src/main/webapp/views/pla3/plaDetl.html                    |   16 +++++
 src/main/webapp/views/pla2/plaDetl.html                    |   16 +++++
 src/main/java/com/zy/asrs/mapper/PlaMapper.java            |    6 ++
 src/main/java/com/zy/asrs/entity/DropdownValuesDto.java    |   16 +++++
 src/main/resources/mapper/PlaMapper.xml                    |    4 +
 10 files changed, 131 insertions(+), 1 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/PlaController.java b/src/main/java/com/zy/asrs/controller/PlaController.java
index f9d4513..592e255 100644
--- a/src/main/java/com/zy/asrs/controller/PlaController.java
+++ b/src/main/java/com/zy/asrs/controller/PlaController.java
@@ -32,6 +32,7 @@
 import java.io.IOException;
 import java.net.URLEncoder;
 import java.util.*;
+import java.util.stream.Collectors;
 
 @RestController
 @Slf4j
@@ -54,6 +55,28 @@
     @Autowired
     private SnowflakeIdWorker snowflakeIdWorker;
 
+    @GetMapping(value = "/pla/dropdownValues/list")
+    @ManagerAuth(memo = "鑾峰彇涓嬫媺閫夋嫨妗嗗�煎垪琛�")
+    public R list() {
+        List<DropdownValuesDto> list = plaService.getDropdownValues();
+        Map<String, List<String>> map = new HashMap<>();
+
+        // owner 鍘婚噸骞跺姞鍏� map
+        List<String> owners = list.stream()
+                .filter(dropdownValuesDto -> dropdownValuesDto.getType().equals("owner"))
+                .map(DropdownValuesDto::getValue)
+                .collect(Collectors.toList());
+        map.put("owner", owners);
+
+        // workshop 鍘婚噸骞跺姞鍏� map
+        List<String> workshops = list.stream()
+                .filter(dropdownValuesDto -> dropdownValuesDto.getType().equals("workshop"))
+                .map(DropdownValuesDto::getValue)
+                .collect(Collectors.toList());
+        map.put("workshop", workshops);
+        return R.ok(map);
+    }
+
 
     @RequestMapping(value = "/pla/list/auth")
     @ManagerAuth
diff --git a/src/main/java/com/zy/asrs/entity/DropdownValuesDto.java b/src/main/java/com/zy/asrs/entity/DropdownValuesDto.java
new file mode 100644
index 0000000..f1fac36
--- /dev/null
+++ b/src/main/java/com/zy/asrs/entity/DropdownValuesDto.java
@@ -0,0 +1,16 @@
+package com.zy.asrs.entity;
+
+import lombok.Data;
+
+/**
+ * @author pang.jiabao
+ * @description 涓嬫媺閫夋嫨妗嗗�奸�氱敤瑙嗗浘
+ * @createDate 2025/10/23 13:36
+ */
+@Data
+public class DropdownValuesDto {
+
+    private String type;
+
+    private String value;
+}
diff --git a/src/main/java/com/zy/asrs/mapper/PlaMapper.java b/src/main/java/com/zy/asrs/mapper/PlaMapper.java
index f6c4c13..30ea888 100644
--- a/src/main/java/com/zy/asrs/mapper/PlaMapper.java
+++ b/src/main/java/com/zy/asrs/mapper/PlaMapper.java
@@ -1,6 +1,7 @@
 package com.zy.asrs.mapper;
 
 import com.baomidou.mybatisplus.mapper.BaseMapper;
+import com.zy.asrs.entity.DropdownValuesDto;
 import com.zy.asrs.entity.Pla;
 import org.apache.ibatis.annotations.Mapper;
 import org.apache.ibatis.annotations.Param;
@@ -26,6 +27,11 @@
     Integer getStockStatisCountAll(Map<String, Object> map);
 
     /**
+     * 鑾峰彇涓嬫媺鍒楄〃鍊�
+     */
+    List<DropdownValuesDto> getDropdownValues();
+
+    /**
      * 鑷姩瑙e喕鍐荤粨鏃堕棿瓒呰繃90澶╃殑搴撳瓨
      * @return 鏇存柊鏁伴噺
      */
diff --git a/src/main/java/com/zy/asrs/service/PlaService.java b/src/main/java/com/zy/asrs/service/PlaService.java
index ea13b76..7caee55 100644
--- a/src/main/java/com/zy/asrs/service/PlaService.java
+++ b/src/main/java/com/zy/asrs/service/PlaService.java
@@ -2,6 +2,7 @@
 
 import com.baomidou.mybatisplus.plugins.Page;
 import com.baomidou.mybatisplus.service.IService;
+import com.zy.asrs.entity.DropdownValuesDto;
 import com.zy.asrs.entity.OrderDetl;
 import com.zy.asrs.entity.Pla;
 import com.zy.asrs.entity.PlaQty;
@@ -11,6 +12,8 @@
 
 public interface PlaService extends IService<Pla> {
 
+    List<DropdownValuesDto> getDropdownValues();
+
     Pla selectByBatchAndPackageNo(String batch, Integer packageNo, String brand);
 
     void queryStock(OrderDetl orderDetl, List<PlaQty> plaQties);
diff --git a/src/main/java/com/zy/asrs/service/impl/PlaServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/PlaServiceImpl.java
index 9eb8ebe..401a7c2 100644
--- a/src/main/java/com/zy/asrs/service/impl/PlaServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/PlaServiceImpl.java
@@ -7,6 +7,7 @@
 import com.core.common.Cools;
 import com.core.common.DateUtils;
 import com.core.exception.CoolException;
+import com.zy.asrs.entity.DropdownValuesDto;
 import com.zy.asrs.entity.OrderDetl;
 import com.zy.asrs.entity.Pla;
 import com.zy.asrs.entity.PlaQty;
@@ -21,6 +22,7 @@
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
+import javax.annotation.Resource;
 import java.util.Date;
 import java.util.List;
 
@@ -29,6 +31,14 @@
     @Autowired
     private PlaQtyService plaQtyService;
 
+    @Resource
+    private PlaMapper plaMapper;
+
+    @Override
+    public List<DropdownValuesDto> getDropdownValues() {
+        return plaMapper.getDropdownValues();
+    }
+
     public Pla selectByBatchAndPackageNo(String batch, Integer packageNo, String brand) {
         return this.selectOne(new EntityWrapper<Pla>().eq("batch",batch).eq("package_no",packageNo).eq("brand",brand));
     }
diff --git a/src/main/resources/mapper/PlaMapper.xml b/src/main/resources/mapper/PlaMapper.xml
index ea2d216..561079f 100644
--- a/src/main/resources/mapper/PlaMapper.xml
+++ b/src/main/resources/mapper/PlaMapper.xml
@@ -43,4 +43,8 @@
         </where>
         GROUP BY brand,matnr,workshop HAVING SUM(weight_anfme) > 0 ORDER BY matnr,workshop
     </select>
+    <select id="getDropdownValues" resultType="com.zy.asrs.entity.DropdownValuesDto">
+        SELECT type, value
+        FROM dropdown_values_view
+    </select>
 </mapper>
\ No newline at end of file
diff --git a/src/main/webapp/static/js/pla/plaDetl.js b/src/main/webapp/static/js/pla/plaDetl.js
index b6ddf4e..c95b607 100644
--- a/src/main/webapp/static/js/pla/plaDetl.js
+++ b/src/main/webapp/static/js/pla/plaDetl.js
@@ -104,6 +104,33 @@
     var form = layui.form;
     admin = layui.admin;
 
+    // 妯℃嫙浠庡悗绔帴鍙h幏鍙栨暟鎹�
+    $.ajax({
+        url: baseUrl + "/pla/dropdownValues/list",
+        headers: {'token': localStorage.getItem('token')},
+        method: 'GET',
+        success: function (res) {
+            if (res.code === 200) {
+                var data = res.data
+
+                if (data.owner && Array.isArray(data.owner)) {
+                    data.owner.forEach(function(item) {
+                        $('#ownerSelect').append(new Option(item, item));
+                    });
+                }
+
+                if (data.workshop && Array.isArray(data.workshop)) {
+                    data.workshop.forEach(function(item) {
+                        $('#workshopSelect').append(new Option(item, item));
+                    });
+                }
+
+                // 閲嶆柊娓叉煋 LayUI 琛ㄥ崟
+                form.render('select');
+            }
+        }
+    });
+
     // 鏃ユ湡鏃堕棿鑼冨洿
     laydate.render({
         elem: '#ID-laydate-range-datetime',
diff --git a/src/main/webapp/views/pla/plaDetl.html b/src/main/webapp/views/pla/plaDetl.html
index de42122..782e8c7 100644
--- a/src/main/webapp/views/pla/plaDetl.html
+++ b/src/main/webapp/views/pla/plaDetl.html
@@ -304,7 +304,16 @@
         </div>
         <div class="layui-inline">
             <div class="layui-input-inline">
-                <input class="layui-input" type="text" name="owner" placeholder="涓讳綋" autocomplete="off">
+                <select id="ownerSelect" name="owner" lay-search>
+                    <option value="">涓讳綋</option>
+                </select>
+            </div>
+        </div>
+        <div class="layui-inline">
+            <div class="layui-input-inline">
+                <select id="workshopSelect" name="workshop" lay-search>
+                    <option value="">杞﹂棿</option>
+                </select>
             </div>
         </div>
         <div class="layui-inline">
diff --git a/src/main/webapp/views/pla2/plaDetl.html b/src/main/webapp/views/pla2/plaDetl.html
index 7497875..5bbd725 100644
--- a/src/main/webapp/views/pla2/plaDetl.html
+++ b/src/main/webapp/views/pla2/plaDetl.html
@@ -296,6 +296,22 @@
             </div>
         </div>
     </div>
+    <div class="layui-form layui-card-header">
+        <div class="layui-inline">
+            <div class="layui-input-inline">
+                <select id="ownerSelect" name="owner" lay-search>
+                    <option value="">涓讳綋</option>
+                </select>
+            </div>
+        </div>
+        <div class="layui-inline">
+            <div class="layui-input-inline">
+                <select id="workshopSelect" name="workshop" lay-search>
+                    <option value="">杞﹂棿</option>
+                </select>
+            </div>
+        </div>
+    </div>
 
 </div>
 <script type="text/html" id="toolbar">
diff --git a/src/main/webapp/views/pla3/plaDetl.html b/src/main/webapp/views/pla3/plaDetl.html
index 72e37dc..a35bb21 100644
--- a/src/main/webapp/views/pla3/plaDetl.html
+++ b/src/main/webapp/views/pla3/plaDetl.html
@@ -296,6 +296,22 @@
             </div>
         </div>
     </div>
+    <div class="layui-form layui-card-header">
+        <div class="layui-inline">
+            <div class="layui-input-inline">
+                <select id="ownerSelect" name="owner" lay-search>
+                    <option value="">涓讳綋</option>
+                </select>
+            </div>
+        </div>
+        <div class="layui-inline">
+            <div class="layui-input-inline">
+                <select id="workshopSelect" name="workshop" lay-search>
+                    <option value="">杞﹂棿</option>
+                </select>
+            </div>
+        </div>
+    </div>
 
 </div>
 <script type="text/html" id="toolbar">

--
Gitblit v1.9.1