From 8e9971722f3f3ed6afd8b17bf73d260a17819914 Mon Sep 17 00:00:00 2001
From: zhang <zc857179121@qq.com>
Date: 星期二, 15 七月 2025 17:51:58 +0800
Subject: [PATCH] 1
---
 src/main/webapp/static/js/order/out.js |  184 ++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 152 insertions(+), 32 deletions(-)
diff --git a/src/main/webapp/static/js/order/out.js b/src/main/webapp/static/js/order/out.js
index c695fb7..1ebda0a 100644
--- a/src/main/webapp/static/js/order/out.js
+++ b/src/main/webapp/static/js/order/out.js
@@ -4,7 +4,7 @@
     base: baseUrl + "/static/layui/lay/modules/"
 }).extend({
     notice: 'notice/notice',
-}).use(['table','laydate', 'form', 'util', 'admin', 'notice', 'treeTable', 'xmSelect', 'tableMerge'], function(){
+}).use(['table','laydate', 'form', 'util', 'admin', 'notice', 'treeTable', 'xmSelect', 'tableMerge', 'tableX'], function(){
     var table = layui.table;
     var $ = layui.jquery;
     var layer = layui.layer;
@@ -16,6 +16,7 @@
     var treeTable = layui.treeTable;
     var xmSelect = layui.xmSelect;
     var tableMerge = layui.tableMerge;
+    var tableX = layui.tableX;
 
     insTb2 = table.render({
         elem: '#orderDetlTable',
@@ -26,21 +27,33 @@
         limits: [15, 30, 50, 100, 200, 500],
         toolbar: '#orderDetToolbar',
         height: 'full-120',
+        where: {order_id: 9999999999},
         cols: [[
             {type: 'checkbox'}
             ,{type: 'numbers', title: '#'}
             ,{field: 'orderNo', align: 'center',title: '鍗曟嵁缂栧彿', templet: '#orderNoTpl', width: 160}
-            ,{field: 'matnr', align: 'center',title: '鍟嗗搧缂栫爜', width: 160}
-            ,{field: 'maktx', align: 'center',title: '鍟嗗搧鍚嶇О', width: 200}
-            ,{field: 'batch', align: 'center',title: '搴忓垪鐮�'}
-            ,{field: 'specs', align: 'center',title: '瑙勬牸'}
+            // ,{field: 'matnr', align: 'center',title: '瑙勬牸', width: 160}
+            // ,{field: 'maktx', align: 'center',title: '鍟嗗搧鍚嶇О', width: 200}
+            // ,{field: 'batch', align: 'center',title: '绠卞彿'}
+            // ,{field: 'specs', align: 'center',title: '鎺ュご'}
             // ,{field: 'anfme', align: 'center',title: '鏁伴噺'}
-            // ,{field: 'qty', align: 'center',title: '浣滀笟鏁伴噺', style: 'font-weight: bold'}
+            ,{field: 'brand', align: 'center',title: '鍖呰缁勫彿'}
+            ,{field: 'supp', align: 'center',title: '瀹㈡埛鍚嶇О', hide: false}
+            ,{field: 'memo', align: 'center',title: '澶囨敞', hide: false}
+            ,{field: 'qty', align: 'center',title: '浣滀笟鏁伴噺', style: 'font-weight: bold'}
             ,{field: 'enableQty', align: 'center',title: '寰呭嚭鏁伴噺', style: 'font-weight: bold'}
+            ,{field: 'finishStatus', align: 'center', title: '鏄惁瀹屾垚', templet: function(d){
+                    if (d.qty === 0 && d.enableQty === 0) {
+                        return '<span style="color:green;font-weight:bold;">瀹屾垚</span>';
+                    } else {
+                        return '<span style="color:red;">鏈畬鎴�</span>';
+                    }
+                }}
+
+
             // ,{field: 'name', align: 'center',title: '鍚嶇О'}
-            // ,{field: 'model', align: 'center',title: '鍨嬪彿'}
-            ,{field: 'unit', align: 'center',title: '鍗曚綅', hide: true}
-            ,{field: 'barcode', align: 'center',title: '鍟嗗搧鏉$爜', hide: true}
+            // ,{field: 'unit', align: 'center',title: '鍗曚綅', hide: true}
+            // ,{field: 'barcode', align: 'center',title: '鍟嗗搧鏉$爜', hide: true}
             // ,{field: 'supplier', align: 'center',title: '渚涘簲鍟�'}
             // ,{field: 'unitPrice', align: 'center',title: '鍗曚环'}
             // ,{field: 'itemNum', align: 'center',title: '鍝侀」鏁�'}
@@ -77,6 +90,7 @@
             limit();
         }
     });
+
     /* 琛ㄦ牸2鎼滅储 */
     form.on('submit(sensorTbSearch)', function (data) {
         insTb2.reload({where: data.field, page: {curr: 1}});
@@ -85,6 +99,7 @@
 
     /* 琛ㄦ牸2澶村伐鍏锋爮鐐瑰嚮浜嬩欢 */
     table.on('toolbar(orderDetlTable)', function (obj) {
+
         var checkStatus = table.checkStatus(obj.config.id).data;
         if (obj.event === 'pakoutPreview') { // 娣诲姞
             if (checkStatus.length === 0) {
@@ -109,6 +124,7 @@
 
     /* 琛ㄦ牸2宸ュ叿鏉$偣鍑讳簨浠� */
     table.on('tool(orderDetlTable)', function (obj) {
+        console.log(obj);
         var data = obj.data;
         switch (obj.event) {
             // 鍑哄簱
@@ -134,8 +150,8 @@
                         type: 1
                         ,title: false
                         ,closeBtn: false
-                        ,offset: '100px'
-                        ,area: ['1200px', '700px']
+                        ,offset: '50px'
+                        ,area: ['1500px', '700px']
                         ,shade: 0.5
                         ,shadeClose: false
                         ,btn: ['绔嬪嵆鍑哄簱', '绋嶅悗澶勭悊']
@@ -151,14 +167,29 @@
                                 limit: Number.MAX_VALUE,
                                 cellMinWidth: 100,
                                 cols: [[
-                                    // {type: 'checkbox', merge: ['orderNo']},
                                     {field: 'orderNo', title: '鍗曟嵁缂栧彿', merge: true, align: 'center'},
-                                    {field: 'title', title: '鍟嗗搧', merge: true, align: 'center', width: 350},
-                                    {field: 'batch', title: '搴忓垪鐮�', align: 'center'},
-                                    {field: 'anfme', title: '鏁伴噺', align: 'center', width: 90, style: 'font-weight: bold'},
+                                    // {type: 'checkbox', merge: ['brand'],width: 100},
+                                    // {field: 'title', title: '鍟嗗搧', merge: true, align: 'center', width: 350},
+                                    {field: 'unit', title: '绠卞彿', align: 'center',hide:false},
+                                    {field: 'model', title: '鍗峰彿', align: 'center', hide: false},
+                                    {
+                                        field: 'threeCode',
+                                        align: 'center',
+                                        title: '鍚堟牸鍚�',
+                                        hide: false,
+                                        templet: function(d) {
+                                            return d.threeCode ? d.threeCode : '寰呭垽';
+                                        }
+                                    },
+                                    // {field: 'specs', title: '鎺ュご', align: 'center'},
+                                    {field: 'brand', align: 'center',title: '鍖呰缁勫彿', merge: true, hide: false},
+                                    // {field: 'brand$', align: 'center',title: '鏈ㄧ绫诲瀷', hide: false},
+                                    // {field: 'zpallet', title: '鎵樼洏鐮�', align: 'center'},
+                                    // {field: 'anfme', title: '鏁伴噺', align: 'center', width: 90, style: 'font-weight: bold'},
+                                    // {field: 'count', title: '鏁伴噺', align: 'center', width: 90, style: 'font-weight: bold'},
                                     {field: 'locNo', title: '璐т綅', align: 'center', width: 100, templet: '#locNoTpl'},
                                     {field: 'staNos', align: 'center', title: '鍑哄簱绔�', merge: ['locNo'], templet: '#tbBasicTbStaNos'},
-                                    {type: 'checkbox', merge: ['locNo']},
+                                    // {type: 'checkbox', merge: ['locNo']},
                                 ]],
                                 done: function (res) {
                                     tableMerge.render(this);
@@ -175,7 +206,6 @@
                                         tableCache[i]['staNo'] = Number(obj.elem.value);
                                     }
                                 }
-                                // data['staNo'] = Number(obj.elem.value);
                                 obj.othis.children().find("input").css("color", "blue");
                                 return false;
                             });
@@ -188,20 +218,73 @@
                                 }
                                 modifySta(stoPreTabData);
                             });
+                            form.on('submit(checkModifySta)', function () {
+                                if (!tableCache || tableCache.length === 0) {
+                                    layer.msg("娌℃湁鍙鐞嗙殑鏁版嵁", {icon: 7});
+                                    return false;
+                                }
+
+                                let updatedRows = [];
+
+                                for (let i = 0; i < tableCache.length; i++) {
+                                    let row = tableCache[i];
+                                    let locNo = row.locNo;
+                                    if (!locNo || locNo.length < 2) continue;
+
+                                    let rowPrefix = parseInt(locNo.substring(0, 2), 10);
+                                    let newStaNo;
+
+                                    if (rowPrefix >= 17 && rowPrefix <= 24) {
+                                        newStaNo = 3092;
+                                    } else if (rowPrefix >= 9 && rowPrefix <= 16) {
+                                        newStaNo = 3102;
+                                    } else if (rowPrefix >= 1 && rowPrefix <= 8) {
+                                        newStaNo = 3095;
+                                    }
+
+                                    if (newStaNo) {
+                                        row.staNo = newStaNo;
+                                        updatedRows.push({index: i, staNo: newStaNo});
+                                    }
+                                }
+
+                                // 閲嶈浇琛ㄦ牸鏁版嵁
+                                stoPreTabIdx.reload({data: tableCache});
+
+                                // 鏇存柊涓嬫媺妗嗛鑹插拰鍊�
+                                updatedRows.forEach(item => {
+                                    $('div[lay-id=stoPreTab] tr[data-index="' + item.index + '"] .order-sta-select').val(item.staNo);
+                                });
+                                layui.form.render('select');
+                                updatedRows.forEach(item => {
+                                    $('div[lay-id=stoPreTab] tr[data-index="' + item.index + '"] .layui-select-title input').css("color", "blue");
+                                });
+
+                                layer.msg("鍑哄簱绔欑偣鍧囧垎宸插畬鎴�", {icon: 1});
+                                return false;
+                            });
+
                             // 鎵归噺淇敼鍑哄簱绔� - 绔欑偣閫夋嫨
                             function modifySta(stoPreTabData) {
                                 // 鍑哄簱绔欏彇浜ら泦
                                 let staBatchSelectVal = [];
                                 for(let i = 0; i<stoPreTabData.length; i++) {
-                                    if (i === 0) {
-                                        staBatchSelectVal = stoPreTabData[i].staNos;
-                                    } else {
-                                        let staNos = stoPreTabData[i].staNos;
-                                        staBatchSelectVal = staBatchSelectVal.filter( val => {
-                                                return new Set(staNos).has(val)
-                                            }
-                                        )
+                                    let staNos = stoPreTabData[i].staNos;
+                                    if (staNos !== null) {
+                                        if (staBatchSelectVal.length === 0) {
+                                            staBatchSelectVal = staNos;
+                                        } else {
+                                            staBatchSelectVal = staBatchSelectVal.filter(val =>
+                                                {
+                                                    return new Set(staNos).has(val)
+                                                }
+                                            )
+                                        }
                                     }
+                                }
+                                if (staBatchSelectVal.length === 0) {
+                                    layer.msg("鍑哄簱绔欐病鏈変氦闆嗭紝鏃犳硶鎵归噺淇敼", {icon: 2});
+                                    return;
                                 }
                                 admin.open({
                                     type: 1,
@@ -215,15 +298,28 @@
                                         $('#batchSelectStaBox').html(template({list: staBatchSelectVal}));
                                         // 纭
                                         form.on('submit(staBatchSelectConfirm)', function (obj) {
-                                            let batchSta = obj.field.batchSta;
-                                            console.log(batchSta)
-                                            for (let i = 0; i<tableCache.length; i++) {
-                                                tableCache[i]['staNo'] = Number(181);
+                                            let loadIdx = layer.load(2);
+                                            let batchSta = Number(obj.field.batchSta);
+                                            let arr = [];
+                                            for (let j = 0; j<stoPreTabData.length; j++) {
+                                                for (let i = 0; i<tableCache.length; i++) {
+                                                    if (tableCache[i].orderNo === stoPreTabData[j].orderNo
+                                                        && tableCache[i].matnr === stoPreTabData[j].matnr
+                                                        && tableCache[i].locNo === stoPreTabData[j].locNo) {
+                                                        tableCache[i]['staNo'] = batchSta;
+                                                        arr.push(i);
+                                                    }
+                                                }
                                             }
-                                            stoPreTabIdx.reload({data: tableCache})
-                                            $('.order-sta-select').val(181);
+                                            stoPreTabIdx.reload({data: tableCache});
+                                            arr.forEach(item => {
+                                                $('div[lay-id=stoPreTab] tr[data-index="' + item + '"] .order-sta-select').val(batchSta);
+                                            });
                                             layui.form.render('select');
-                                            layer.close(ddIndex);
+                                            arr.forEach(item => {
+                                                $('div[lay-id=stoPreTab] tr[data-index="' + item + '"] .layui-select-title').find("input").css("color", "blue");
+                                            });
+                                            layer.close(loadIdx); layer.close(ddIndex);
                                             return false;
                                         });
                                         // 寮圭獥涓嶅嚭鐜版粴鍔ㄦ潯
@@ -319,6 +415,8 @@
         })
     })
 
+    window.pakoutPreview = pakoutPreview;
+
 });
 
 function tableReload(child) {
@@ -334,3 +432,25 @@
     });
 }
 
+/**
+ * 涓�閿嚭搴�
+ */
+function autoOut(orderId) {
+    let loadIndex = layer.msg('璇锋眰涓�...', {icon: 16, shade: 0.01, time: false});
+    $.ajax({
+        url: baseUrl + "/out/pakout/orderDetlIds/auth",
+        headers: {'token': localStorage.getItem('token')},
+        data: { orderId : orderId },
+        method: 'POST',
+        success: function (res) {
+            layer.close(loadIndex);
+            if (res.code === 200){
+                pakoutPreview(res.data);
+            } else if (res.code === 403){
+                top.location.href = baseUrl+"/";
+            } else {
+                layer.msg(res.msg, {icon: 2});
+            }
+        }
+    })
+}
--
Gitblit v1.9.1