From 886ec394c38d842e1a2ef099782fbc93409e9d16 Mon Sep 17 00:00:00 2001
From: zyx <zyx123456>
Date: 星期一, 29 一月 2024 09:56:19 +0800
Subject: [PATCH] 修复卡顿Bug
---
 src/main/webapp/static/js/pakStore/stockAdjust.js |  190 +++++++++++++++++++++++++++--------------------
 1 files changed, 108 insertions(+), 82 deletions(-)
diff --git a/src/main/webapp/static/js/pakStore/stockAdjust.js b/src/main/webapp/static/js/pakStore/stockAdjust.js
index 28bbd96..d51a7b8 100644
--- a/src/main/webapp/static/js/pakStore/stockAdjust.js
+++ b/src/main/webapp/static/js/pakStore/stockAdjust.js
@@ -2,12 +2,35 @@
 var initAnfmeVal = "-";
 var matCodeData = [];
 var currLocNo;
-layui.use(['table','laydate', 'form'], function() {
+var matCodeLayerIdx;
+function getCol() {
+    var cols = [
+        {fixed: 'left', field: 'count', title: '瀹為檯鏁伴噺', align: 'center', edit:'text', width: 120,  style:'color: blue;font-weight: bold'}
+        ,{field: 'anfme', align: 'center',title: '鏁伴噺'}
+        ,{field: 'batch', align: 'center',title: '搴忓垪鐮�', edit: true, style: 'font-weight:bold'}
+        ,{field: 'threeCode', align: 'center',title: '閿�鍞鍗曞彿', edit: true, style: 'font-weight:bold'}
+        ,{field: 'deadTime', align: 'center',title: '閿�鍞鍗曡鍙�', edit: true, style: 'font-weight:bold'}
+        ,{field: 'suppCode', align: 'center',title: '鏂欑鐮�', edit: false, style: 'font-weight:bold'}
+    ];
+    arrRemove(detlCols, "field", "zpallet");
+    arrRemove(detlCols, "field", "anfme");
+    arrRemove(detlCols, "field", "batch");
+    arrRemove(detlCols, "field", "threeCode");
+    arrRemove(detlCols, "field", "deadTime");
+    cols.push.apply(cols, detlCols);
+    cols.push({fixed: 'right', title:'鎿嶄綔', align: 'center', toolbar: '#operate', width:80})
+    return cols;
+}
+
+layui.config({
+    base: baseUrl + "/static/layui/lay/modules/"
+}).use(['table','laydate', 'form', 'admin'], function() {
     var table = layui.table;
     var $ = layui.jquery;
     var layer = layui.layer;
     var layDate = layui.laydate;
     var form = layui.form;
+    var admin = layui.admin;
 
     tableIns = table.render({
         elem: '#chooseData',
@@ -16,16 +39,7 @@
         limit: 500,
         cellMinWidth: 50,
         toolbar: '#toolbar',
-        cols: [[
-            {fixed: 'left', field: 'count', title: '瀹為檯鏁伴噺', align: 'center', edit:'text', width: 120,  style:'color: blue;font-weight: bold'},
-            {field: 'anfme', align: 'center',title: '鏁伴噺'},
-            {field: 'matNo', align: 'center', title: '鐗╂枡缂栫爜'},
-            {field: 'barcode', align: 'center', title: '鏉$爜'},
-            {field: 'matName', align: 'center', title: '鐗╂枡鍚嶇О'},
-            {field: 'str1', align: 'center', title: '鐗╂枡鍗曚綅'},
-            {field: 'str2', align: 'center', title: '鐗╂枡瑙勬牸'},
-            {fixed: 'right', title:'鎿嶄綔', align: 'center', toolbar: '#operate', width:80}
-        ]],
+        cols: [getCol()],
         done: function (res, curr, count) {
             limit();
         }
@@ -33,7 +47,25 @@
 
     // 椤甸潰淇敼
     table.on('edit(chooseData)', function (obj) {
-        updateMatCodeData(obj.data.matNo, Number(obj.value));
+        let index = obj.tr.attr("data-index");
+        let data = matCodeData[index];
+        let modify = true;
+        if (obj.field === 'count'){
+            let vle = Number(obj.value);
+            if (isNaN(vle)) {
+                layer.msg("璇疯緭鍏ユ暟瀛�", {icon: 2});
+                modify = false;
+            } else {
+                if (vle <= 0) {
+                    layer.msg("鏁伴噺蹇呴』澶т簬闆�", {icon: 2});
+                    modify = false;
+                }
+            }
+        }
+        if (modify) {
+            data[obj.field] = obj.value;
+        }
+        tableIns.reload({data: matCodeData});
     });
 
     // 鐩戝惉澶村伐鍏锋爮浜嬩欢
@@ -41,21 +73,21 @@
         switch(obj.event) {
             case 'adjust':
                 if (isEmpty(currLocNo)) {
-                    layer.msg("璇峰厛妫�绱㈠簱浣�")
+                    layer.msg("璇峰厛妫�绱㈠簱浣�", {icon: 2})
                     inputTip($("#searchLocNo"));
                     return;
                 }
                 if (matCodeData.length === 0) {
-                    layer.msg("璇峰厛娣诲姞鐗╂枡");
+                    layer.msg("璇峰厛娣诲姞鏄庣粏", {icon: 2});
                     return;
                 }
                 for (var i=0;i<matCodeData.length;i++){
                     if (isNaN(matCodeData[i].count)) {
-                        layer.msg("璇疯緭鍏ユ暟瀛�");
+                        layer.msg("璇疯緭鍏ユ暟瀛�", {icon: 2});
                         return;
                     }
                     if (matCodeData[i].count < 0){
-                        layer.msg("鏁伴噺涓嶈兘灏忎簬闆�");
+                        layer.msg("鏁伴噺涓嶈兘灏忎簬闆�", {icon: 2});
                         return;
                     }
                 }
@@ -72,12 +104,12 @@
                         async: false,
                         success: function (res) {
                             if (res.code === 200){
-                                layer.msg(currLocNo + res.msg);
-                                reset();
+                                layer.msg(currLocNo + res.msg, {icon: 1});
+                                init(currLocNo)
                             } else if (res.code === 403){
                                 top.location.href = baseUrl+"/";
                             }else {
-                                layer.msg(res.msg)
+                                layer.msg(res.msg, {icon: 2})
                             }
                         }
                     })
@@ -91,12 +123,9 @@
         var data = obj.data;
         switch (obj.event) {
             case 'remove':
-                for (var i = matCodeData.length - 1; i >= 0; i--) {
-                    if (matCodeData[i].matNo === data.matNo) {
-                        matCodeData.splice(i, 1);
-                    }
-                }
-                tableIns.reload({data: matCodeData,done:function (res) {limit();}});
+                let index = obj.tr.attr("data-index");
+                matCodeData.splice(index, 1);
+                tableIns.reload({data: matCodeData});
                 break;
         }
     });
@@ -109,27 +138,25 @@
             layer.msg("璇疯緭鍏ュ簱浣嶅彿");
             return;
         }
-        http.post(baseUrl + "/locDetl/list/auth", {locNo: locNo,limit: 1000}, function (res) {
-            matCodeData = [];
-            let data = res.data.records;
-            for (var i = 0; i<data.length; i++) {
-                matCodeData.push({
-                    count: data[i].anfme,
-                    anfme: data[i].anfme,
-                    matNo: data[i].matnr,
-                    matName: data[i].maktx,
-
-                })
-            }
-            locTips(true, locNo);
-            tableReload();
-        })
+        init(locNo);
     });
 
     // 閲嶇疆浜嬩欢
     form.on('submit(reset)', function (data) {
         reset();
     });
+
+    function init(locNo) {
+        http.post(baseUrl + "/locDetl/list/auth", {locNo: locNo,limit: 1000}, function (res) {
+            matCodeData = [];
+            matCodeData = res.data.records;
+            for (var i = 0; i<matCodeData.length; i++) {
+                matCodeData[i]["count"] = matCodeData[i]["anfme"];
+            }
+            locTips(true, locNo);
+            tableReload();
+        })
+    }
 
     function reset() {
         clearFormVal($('#search-box'));
@@ -140,9 +167,7 @@
 
     // 閲嶈浇琛ㄦ牸
     function tableReload() {
-        tableIns.reload({data: matCodeData,done:function (res) {
-                limit();
-            }});
+        tableIns.reload({data: matCodeData});
     }
 
     // 搴撲綅鎻愮ず妗�
@@ -152,11 +177,11 @@
                 let data = res.data;
                 if (data != null) {
                     $(".retrieve").show();
-                    $("#locMsg").html(locNo + " ,搴撲綅鐘舵�侊細" + data.locType$);
+                    $("#locMsg").html(locNo + " ,搴撲綅鐘舵�侊細" + data.locSts$);
                     $('.not-retrieve').hide();
                     currLocNo = locNo;
                 } else {
-                    layer.msg("璇疯緭鍏ユ湁鏁堝簱浣嶅彿");
+                    layer.msg("璇疯緭鍏ユ湁鏁堝簱浣嶅彿", {icon: 2});
                     $('.not-retrieve').show();
                     $("#locMsg").html("");
                     $(".retrieve").hide();
@@ -172,45 +197,28 @@
         }
     }
 
-    function updateMatCodeData(matNo, count) {
-        if (isNaN(count)) {
-            layer.msg("璇疯緭鍏ユ暟瀛�");
-        } else {
-            if (count > 0) {
-                for (var i=0;i<matCodeData.length;i++){
-                    if (matCodeData[i]["matNo"] === matNo){
-                        matCodeData[i]["count"] = count;
-                    }
-                }
-            } else {
-                layer.msg("鏁伴噺蹇呴』澶т簬闆�");
+    $(document).on('click','#mat-query', function () {
+        if (isEmpty(currLocNo)) {
+            layer.msg("璇峰厛妫�绱㈠簱浣�")
+            inputTip($("#searchLocNo"));
+            return;
+        }
+        let loadIndex = layer.msg('璇锋眰涓�...', {icon: 16, shade: 0.01, time: false});
+        matCodeLayerIdx = admin.open({
+            type: 2,
+            title: false,
+            closeBtn: false,
+            maxmin: false,
+            area: ['90%', '85%'],
+            shadeClose: true,
+            content: 'matQuery.html',
+            success: function(layero, index){
+                layer.close(loadIndex);
             }
-        }
-        tableIns.reload({data: matCodeData,done:function (res) {
-                limit();
-            }});
-    }
-})
+        });
+    })
 
-// 鎻愬彇鐗╂枡
-var matCodeLayerIdx;
-function getMat() {
-    if (isEmpty(currLocNo)) {
-        layer.msg("璇峰厛妫�绱㈠簱浣�")
-        inputTip($("#searchLocNo"));
-        return;
-    }
-    matCodeLayerIdx = layer.open({
-        type: 2,
-        title: '鎻愬彇鐗╂枡',
-        maxmin: true,
-        area: [top.detailWidth, top.detailHeight],
-        shadeClose: true,
-        content: 'matQuery.html',
-        success: function(layero, index){
-        }
-    });
-}
+})
 
 // 鎼滅储妗嗙┖鍊兼彁绀�
 function inputTip(el) {
@@ -219,3 +227,21 @@
         el.css("border-color", "#b8b8b8");
     }, 1000);
 }
+
+// 娣诲姞琛ㄦ牸鏁版嵁
+function addTableData(data) {
+    for (let i=0;i<data.length;i++){
+        for (let j=0;j<matCodeData.length;j++){
+            if (data[i].matnr === matCodeData[j].matnr && data[i].batch === matCodeData[j].batch) {
+                data.splice(i, 1);
+                break;
+            } else {
+                data[i]['anfme'] = initAnfmeVal;
+                data[i]['count'] = initCountVal;
+            }
+        }
+    }
+    matCodeData.push.apply(matCodeData, data);
+    tableIns.reload({data: matCodeData});
+    layer.close(matCodeLayerIdx);
+}
--
Gitblit v1.9.1