From f111076ba746238c20472121993495ac5df4b54b Mon Sep 17 00:00:00 2001
From: zhangc <zc@123>
Date: 星期三, 15 一月 2025 14:38:26 +0800
Subject: [PATCH] 添加订单视图及控制器,优化订单详情展示

---
 src/main/webapp/static/js/order/order.js |  142 ++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 121 insertions(+), 21 deletions(-)

diff --git a/src/main/webapp/static/js/order/order.js b/src/main/webapp/static/js/order/order.js
index 88dd47d..a2cdbef 100644
--- a/src/main/webapp/static/js/order/order.js
+++ b/src/main/webapp/static/js/order/order.js
@@ -44,22 +44,26 @@
         cellMinWidth: 100,
         cols: [[
             {type: 'numbers'},
+            {field: 'defNumber', align: 'center', title: '鎿嶄綔绯荤粺鍙�', hide: false, width: 100},
+            {field: '鎿嶄綔鍗曟嵁', align: 'center', title: '鎿嶄綔鍗曟嵁', hide: true},
+            {field: '鎿嶄綔绫诲瀷', align: 'center', title: '鎿嶄綔绫诲瀷', hide: true},
             {field: 'orderNo', title: '鍗曟嵁缂栧彿', templet: '#orderNoTpl'},
-            {field: 'itemName', align: 'center', title: '鏍哥畻涓讳綋'},
+            //{field: 'itemName', align: 'center', title: '鏍哥畻涓讳綋'},
             {field: 'docType$', align: 'center', title: '鍗曟嵁绫诲瀷'},
-            {field: 'defNumber', align: 'center', title: '涓氬姟绫诲瀷'},
+            //{field: 'defNumber', align: 'center', title: '涓氬姟绫诲瀷'},
             //{field: 'postFee', align: 'center', title: '鎬绘暟閲�',  minWidth: 130, width: 130},
             {align: 'center', title: '鏄庣粏', toolbar: '#tbLook', minWidth: 160, width: 160},
+            {field: 'orderTime', align: 'center',title: '鍗曟嵁鏃ユ湡'},
+            //{field: 'shipCode', align: 'center',title: '鍒跺崟浜�'},
+            {field: 'createBy$', title: '鍒涘缓浜�'},
             {field: 'createTime$', title: '鍒涘缓鏃堕棿'},
-            {field: 'settle$', align: 'center', title: '鐘舵��', templet: '#settleTpl',  minWidth: 160, width: 160},
+            {field: 'settle$', align: 'center', title: '鐘舵��', templet: '#settleTpl',  minWidth: 140, width: 140},
             {field: 'memo', align: 'center',title: '澶囨敞', hide: true},
-            {field: 'orderTime', align: 'center',title: '鍗曟嵁鏃ユ湡', hide: true},
             {field: 'cstmrName', align: 'center',title: '渚涘簲鍟�/瀹㈡埛缂栫爜', hide: true},
             {field: 'tel', align: 'center',title: '浠撳簱', hide: true},
             {field: 'operMemb', align: 'center',title: '鍑哄叆搴撶被鍒�', hide: true},
             {field: 'salesman', align: 'center',title: '閮ㄩ棬', hide: true},
-            {field: 'shipCode', align: 'center',title: '鍒跺崟浜�', hide: true},
-            {align: 'center', title: '鎿嶄綔', toolbar: '#operate', width: 180}
+            {align: 'center', title: '鎿嶄綔', toolbar: '#operate', width: 160}
         ]],
         request: {
             pageName: 'curr',
@@ -100,6 +104,10 @@
         $("#importExcel").trigger("click");
     });
 
+     $("#orderCheckBtn").click(function () {
+            $("#importExcel2").trigger("click");
+        });
+
     // 宸ュ叿鏉$偣鍑讳簨浠�
     table.on('tool(order)', function (obj) {
         var data = obj.data;
@@ -122,8 +130,8 @@
             layer.open({
                 type: 1,
                 title: false,
-                area: '1460px',
-                offset: [top + 'px', (left - 900 + $a.outerWidth()) + 'px'],
+                area: '1100px',
+                offset: [top + 'px', (left - 530 + $a.outerWidth()) + 'px'],
                 shade: .01,
                 shadeClose: true,
                 fixed: false,
@@ -140,8 +148,8 @@
                         cellMinWidth: 100,
                         cols: [[
                             {type: 'numbers'},
-                            {field: 'matnr', title: '瀛樿揣缂栫爜', width: 160},
-                            {field: 'maktx', title: '瀛樿揣鍚嶇О', width: 160},
+                            {field: 'matnr', title: '鍟嗗搧缂栫爜', width: 140},
+                            {field: 'maktx', title: '鍟嗗搧鍚嶇О', width: 150},
                             {field: 'batch', title: '鎵瑰彿'},
                             {field: 'anfme', title: '鏁伴噺'},
                             {field: 'qty', title: '浣滀笟鏁伴噺', style: 'font-weight: bold'},
@@ -153,12 +161,15 @@
                             // },
                             // {field: 'inQty', title: '宸插叆搴撻噺'},
                             // {field: 'color', title: '棰滆壊'},
-                            {field: 'specs', title: '瑙勬牸鍨嬪彿'},
+                            //{field: 'specs', title: '瑙勬牸鍨嬪彿'},
                             {field: 'unit', title: '璁¢噺鍗曚綅'},
-                            {field: 'brand', title: '琛屽彿'},
-                            {field: 'color', title: '閿�鍞鍗曞彿'},
-                            {field: 'origin', title: '閿�鍞鍗曡鍙�'},
-                            {field: 'itemNum', title: '琛屽敮涓�鏍囪瘑'}
+                            //{field: 'manu', title: '琛屽彿'},
+                            {field: 'threeCode', title: '閿�鍞崟鍙�'},
+                            //{field: 'deadTime', title: '鑷敱椤�'},
+                            {field: 'processSts$', title: '宸ュ簭'},
+                            //{field: 'specs', title: '瑙勬牸'},
+                            {field: 'reportQty', title: '涓婃姤鏁伴噺'},
+                            //{field: 'itemNum', title: '琛屽敮涓�鏍囪瘑'}
                         ]],
                         request: {
                             pageName: 'curr',
@@ -191,7 +202,7 @@
             type: 1,
             title: (expTpe ? '淇敼' : '娣诲姞') + '鍗曟嵁',
             content: $('#editDialog').html(),
-            area: '1300px',
+            area: '1600px',
             success: function (layero, dIndex) {
                 $(layero).children('.layui-layer-content').css('overflow', 'visible');
                 var isExpAdd = !expTpe;
@@ -248,22 +259,52 @@
                     headers: {token: localStorage.getItem('token')},
                     data: xxDataList,
                     page: true,
-                    height: '350px;',
+                    //height: '350px;',
                     cellMinWidth: 100,
+
+                    css: [ // 璁剧疆鍗曞厓鏍兼牱寮�
+                        // 鍙栨秷榛樿鐨勬孩鍑洪殣钘忥紝骞惰缃�傚綋楂樺害
+                        '.layui-table-cell{height: 50px; line-height: 40px;}',
+                        '.layui-table-cell .layui-colorpicker{width: 38px; height: 38px;}',
+                        '.layui-table-cell select{height: 36px; padding: 0 5px;}'
+                    ].join(''),
                     cols: [[
                         {type: 'numbers', title: '#'},
-                        {field: 'matnr', title: '鐗╂枡鍙�', width: 160},
-                        {field: 'maktx', title: '鐗╂枡鍚嶇О', width: 200},
+                        {field: 'matnr', title: '鍟嗗搧缂栫爜', width: 160},
+                        {field: 'maktx', title: '鍟嗗搧鍚嶇О', width: 160},
                         {field: 'batch', title: '搴忓垪鐮�', edit: true},
                         {field: 'specs', title: '瑙勬牸'},
                         {field: 'anfme', title: '鏁伴噺(淇敼)', style: 'color: blue;font-weight: bold', edit: true, minWidth: 110, width: 110},
+                        {field: 'threeCode', title: '閿�鍞鍗曞彿(淇敼)', style: 'color: blue;font-weight: bold', edit: 'text', minWidth: 110, width: 110},
+                        {field: 'deadTime', title: '閿�鍞鍗曡鍙�(淇敼)', style: 'color: blue;font-weight: bold', edit: 'text', minWidth: 110, width: 110},
+                        {field: 'processSts', title: '宸ュ簭', templet: function (d) {
+                            var select = `<select class="layui-select" name="processSts" data-state=${d.processSts} lay-filter="processStsSelect" data-value=${d.processSts} id=${d.id}>
+                                            <option value="">閫夋嫨鐘舵��</option>
+                                            <option value="1">寰呭姞宸�</option>
+                                            <option value="2">宸插姞宸�</option>
+                                            <option value="3">鏃犻渶鍔犲伐</option>
+                                        </select>`;
+                            return select;
+                            }},
                         // {field: 'inQty', title: '宸插叆搴撻噺',  minWidth: 100, width: 100},
                         // {field: 'unit', title: '鍗曚綅', width: 80},
                         {field: 'memo', title: '澶囨敞' , edit: true},
                         {align: 'center', title: '鎿嶄綔', toolbar: '#formSSXMTableBar', minWidth: 80, width: 80, fixed: 'right'}
                     ]],
-                    done: function (res) {
+                    done: function (res,curr, count) {
                         $(layero).find('.layui-table-view').css('margin', '0');
+                        $(".layui-table-body").css('overflow','visible');
+                        $(".layui-table-box").css('overflow','visible');
+                        $(".layui-table-view").css('overflow','visible');
+
+                        var tableElem = this.elem.next('.layui-table-view');
+                        count || tableElem.find('.layui-table-header').css('overflow', 'auto');
+                        layui.each(tableElem.find('select[name="processSts"]'), function (index, item) {
+                            var elem = $(item);
+                            elem.val(elem.data('state')).parents('div.layui-table-cell').css('overflow', 'visible');
+                        });
+
+                        form.render();//鍒锋柊琛ㄥ崟
                     },
                     size: ''
                 };
@@ -308,9 +349,24 @@
                         });
                     }
                 });
+                // 宸ュ叿鏉$偣鍑讳簨浠�
+                form.on('select(processStsSelect)', function (obj) {
+                    console.log(obj)
+                    var id = obj.elem.id
+                    var val = obj.value
+                    for (let item of xxDataList) {
+                        if (item.id == id) {
+                            item.processSts = val
+                        }
+                    }
+                });
                 // 鏄庣粏鏁版嵁淇敼
                 table.on('edit(formSSXMTable)', function (obj) {
-                    let index = obj.tr.attr("data-index");
+                    let index = 0;
+                    for (let k in xxDataList) {
+                        if (obj.data.id === xxDataList[k].id)
+                            index = k
+                    }
                     let data = xxDataList[index];
                     if (obj.field === 'anfme'){
                         let vle = Number(obj.value);
@@ -627,3 +683,47 @@
     alert(res.msg);
     // layer.msg(res.msg, {icon: 2});
 }
+
+
+function upload2(obj){
+    if(!obj.files) {
+        return;
+    }
+    var file = obj.files[0];
+    admin.confirm('纭瀵煎叆 [' + file.name +'] 鏂囦欢鍚楋紵', function (index) {
+            layer.load(1, {shade: [0.1,'#fff']});
+            var url = baseUrl + "/order/excel/import2/auth";
+            var form = new FormData();
+            form.append("file", file);
+            let xhr = new XMLHttpRequest();
+            xhr.open("post", url, true);
+            xhr.setRequestHeader('token', localStorage.getItem('token'));
+            xhr.onload = uploadComplete;
+            xhr.onerror =  uploadFailed;
+            xhr.onloadend = function () {
+                layer.closeAll('loading');
+            };
+            // xhr.upload.onprogress = progressFunction;
+            xhr.upload.onloadstart = function(){
+                ot = new Date().getTime();
+                oloaded = 0;
+            };
+            xhr.send(form);
+        }, function(index){
+        });
+}
+function uploadComplete(evt) {
+    let res = JSON.parse(evt.target.responseText);
+    if(res.code === 200) {
+        layer.msg(res.msg, {icon: 1});
+        insTb.reload({page: {curr: 1}});
+    } else {
+        alert(res.msg);
+        // layer.msg(res.msg, {icon: 2});
+    }
+}
+function uploadFailed(evt) {
+    let res = JSON.parse(evt.target.responseText);
+    alert(res.msg);
+    // layer.msg(res.msg, {icon: 2});
+}

--
Gitblit v1.9.1