From e34c002fefc989c22c69918319a55394e72e50d3 Mon Sep 17 00:00:00 2001 From: LSH Date: 星期五, 22 十二月 2023 09:58:46 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/mdqdasrsVersion' into mdqdasrsVersion --- src/main/webapp/static/js/order/order.js | 409 +++++++++++++++++++++++++++++++++++++++++++++------------- 1 files changed, 317 insertions(+), 92 deletions(-) diff --git a/src/main/webapp/static/js/order/order.js b/src/main/webapp/static/js/order/order.js index 5cd8afc..abe7000 100644 --- a/src/main/webapp/static/js/order/order.js +++ b/src/main/webapp/static/js/order/order.js @@ -1,3 +1,5 @@ +var insTbCount = 0; +var printMatCodeNos = []; layui.config({ base: baseUrl + "/static/layui/lay/modules/" }).use(['layer', 'form', 'table', 'util', 'admin', 'xmSelect', 'laydate'], function () { @@ -10,6 +12,27 @@ var xmSelect = layui.xmSelect; var layDate = layui.laydate; + // 娓叉煋鎼滅储妯℃澘 + $.ajax({ + url: baseUrl+"/docType/list/auth", + headers: {'token': localStorage.getItem('token')}, + data: { + limit: 9999 + }, + method: 'POST', + success: function (res) { + if (res.code === 200){ + let template = Handlebars.compile($('#docTypeTpl').html()); + $('#docType-query').html(template(res.data)); + layui.form.render('select'); + } else if (res.code === 403){ + top.location.href = baseUrl+"/"; + } else { + layer.msg(res.msg, {icon: 2}) + } + } + }) + // 娓叉煋琛ㄦ牸 var insTb = table.render({ elem: '#order', @@ -19,13 +42,14 @@ cellMinWidth: 100, cols: [[ {type: 'numbers'}, - {field: 'orderNo', title: '鍗曟嵁缂栧彿', sort: true}, + {field: 'orderNo', title: '鍗曟嵁缂栧彿'}, {field: 'docType$', align: 'center', title: '绫诲瀷', minWidth: 160, width: 160}, {align: 'center', title: '鏄庣粏', toolbar: '#tbLook', minWidth: 160, width: 160}, {field: 'createTime$', title: '鍒涘缓鏃堕棿', minWidth: 200, width: 200}, {field: 'settle$', align: 'center', title: '鐘舵��', templet: '#settleTpl', minWidth: 160, width: 160}, {field: 'memo', align: 'center',title: '澶囨敞', hide: true}, - {align: 'center', title: '鎿嶄綔', toolbar: '#operate', minWidth: 130, width: 130} + {field: 'createBy$', align: 'center', title: '鎿嶄綔鍛�', minWidth: 160, width: 160}, + {align: 'center', title: '鎿嶄綔', toolbar: '#operate', width: 260} ]], request: { pageName: 'curr', @@ -43,9 +67,11 @@ statusCode: 200 }, done: function (res, curr, count) { + limit(); if (res.code === 403) { top.location.href = baseUrl+"/"; } + insTbCount = count; } }); @@ -58,15 +84,87 @@ $("#orderAddBtn").click(function () { showEditModel(); }); + function btnPrint(id, orderNo, number) { + printMatCodeNos.push(orderNo) + var templateNo = 3; + $.ajax({ + url: baseUrl+"/order/print/auth", + headers: {'token': localStorage.getItem('token')}, + data: {param: printMatCodeNos}, + method: 'POST', + async: false, + success: function (res) { + if (res.code === 200){ + layer.closeAll(); + console.log(res); + for (let i=0;i<res.data.length;i++){ + var templateDom = $("#templatePreview"+templateNo); + var className = templateDom.attr("class"); + if (className === 'template-barcode') { + res.data[i]["barcodeUrl"]=baseUrl+"/mac/code/auth?type=1¶m="+res.data[i].orderNo+ + ";"+res.data[i].matnr+";"+res.data[i].batch; + } else { + res.data[i]["barcodeUrl"]=baseUrl+"/mac/code/auth?type=2¶m="+res.data[i].orderNo+ + ";"+res.data[i].matnr+";"+res.data[i].batch; + } + } + var tpl = templateDom.html(); + var template = Handlebars.compile(tpl); + var html = template(res); + var box = $("#box"); + box.html(html);box.show(); + box.print({mediaPrint:true}); + box.hide(); + } else if (res.code === 403){ + top.location.href = baseUrl+"/"; + }else { + layer.msg(res.msg) + } + } + }) + } + function addPakOut(expTpe) { + $.ajax({ + url: baseUrl+"/pakout/add/auth", + headers: {'token': localStorage.getItem('token')}, + data: JSON.stringify({ + docType: Number(20), + orderNo: expTpe, + }), + contentType:'application/json;charset=UTF-8', + method: 'POST', + success: function (res) { + if (res.code === 200){ + layer.msg("鐢熸垚鎷h揣鍗曪細ok"); + } else if (res.code === 403){ + layer.msg("鐢熸垚鎷h揣鍗曞け璐ワ細403"); + }else { + layer.msg("鐢熸垚鎷h揣鍗曞け璐ワ細鏈煡寮傚父"); + } + + } + }) + } + // 宸ュ叿鏉$偣鍑讳簨浠� table.on('tool(order)', function (obj) { var data = obj.data; var layEvent = obj.event; + + + if (layEvent === 'edit') { showEditModel(data); } else if (layEvent === 'del') { - doDel(data.billNo); + doDel(data.id); + }else if (layEvent === 'btnPrint') { + //btnPrint(data.id, data.orderNo, 4); + btnPrint2(data.id, data.orderNo, 4); + } else if (layEvent === 'complete') { + doModify(data.id, data.orderNo, 4); + }else if (layEvent === 'manPrint') { + addPakOut(data.orderNo); } else if (layEvent === 'look') { var $a = $(obj.tr).find('a[lay-event="look"]'); var offset = $a.offset(); @@ -75,7 +173,7 @@ layer.open({ type: 1, title: false, - area: '750px', + area: '820px', offset: [top + 'px', (left - 530 + $a.outerWidth()) + 'px'], shade: .01, shadeClose: true, @@ -93,11 +191,15 @@ cellMinWidth: 100, cols: [[ {type: 'numbers'}, - {field: 'matnr', title: '鍟嗗搧缂栫爜'}, + {field: 'matnr', title: '鍟嗗搧缂栫爜', width: 160}, {field: 'maktx', title: '鍟嗗搧鍚嶇О', width: 160}, - {field: 'batch', title: '鎵瑰彿'}, + {field: 'owner$', title: '璐т富', width: 160}, + {field: 'payment$', title: '璐х墿鐗瑰緛', width: 160}, + // {field: 'batch', title: '鎵瑰彿'}, {field: 'anfme', title: '鏁伴噺'}, - {field: 'unit', title: '鍗曚綅'}, + {field: 'workQty', title: '浣滀笟鏁伴噺'}, + {field: 'qty', title: '瀹屾垚鏁伴噺', style: 'font-weight: bold'}, + // {field: 'unit', title: '鍗曚綅'}, // { // field: 'createTime$', title: '鍒涘缓鏃堕棿', sort: true, templet: function (d) { // return util.toDateString(d.createTime); @@ -105,7 +207,8 @@ // }, // {field: 'inQty', title: '宸插叆搴撻噺'}, // {field: 'color', title: '棰滆壊'}, - {field: 'specs', title: '瑙勬牸'} + // {field: 'specs', title: '瑙勬牸'}, + {field: 'weight', title: '閲嶉噺'} ]], request: { pageName: 'curr', @@ -130,12 +233,13 @@ } }); } + else if (layEvent === 'printExcel'){ + printExcel(data); + } }); // 鏄剧ず琛ㄥ崟寮圭獥 function showEditModel(expTpe) { - var mlist=null - var inQtys=[] admin.open({ type: 1, title: (expTpe ? '淇敼' : '娣诲姞') + '鍗曟嵁', @@ -157,30 +261,20 @@ return false; } let nList = admin.util.deepClone(xxDataList); + console.log(nList); for (let xi = 0; xi < nList.length; xi++) { - // if (nList[xi].inQty > 0 && inQtys[xi] !== nList[xi].anfme) { - // layer.msg("宸插叆搴撴棤娉曚慨鏀�", {icon: 2}) - // return false; - // } else if (nList[xi].anfme > 0) { - // param.push({ - // billNo: data.field.billNo, - // billType: data.field.billType, - // matNo: nList[xi].matNo, - // matName: nList[xi].matName, - // color: nList[xi].color, - // size: nList[xi].size, - // specs: nList[xi].specs, - // memo: nList[xi].memo, - // unit: nList[xi].unit, - // qty: nList[xi].qty, - // inQty: nList[xi].inQty, - // }) - // } else if (nList[xi].anfme <= 0){ - // layer.msg('鏄庣粏淇敼鏁伴噺涓嶅悎娉�', {icon: 2}); - // return false; - // } if (nList[xi].anfme <= 0){ layer.msg('鏄庣粏淇敼鏁伴噺涓嶅悎娉�', {icon: 2}); + return false; + } + if (nList[xi].anfme < nList[xi].workQty){ + layer.msg('鏁伴噺涓嶈兘灏忎簬宸蹭綔涓氭暟閲�', {icon: 2}); + return false; + } + } + for (let xi = 0; xi < nList.length; xi++) { + if (nList[xi].owner <= 0){ + layer.msg('璐т富缂栧彿璇锋煡鐪嬭揣涓绘。妗�', {icon: 2}); return false; } } @@ -189,6 +283,7 @@ url: baseUrl+"/order/form/" + (isExpAdd?"add":"modify") + "/auth", headers: {'token': localStorage.getItem('token')}, data: JSON.stringify({ + orderId: Number(data.field.id), docType: Number(data.field.docType), orderNo: data.field.orderNo, orderDetlList: nList @@ -199,7 +294,7 @@ layer.closeAll('loading'); if (res.code === 200){ layer.close(dIndex); - insTb.reload({page: {curr: 1}}); + $(".layui-laypage-btn")[0].click(); layer.msg(res.msg, {icon: 1}); } else if (res.code === 403){ top.location.href = baseUrl+"/"; @@ -223,24 +318,44 @@ {type: 'numbers', title: '#'}, {field: 'matnr', title: '鍟嗗搧缂栫爜', width: 160}, {field: 'maktx', title: '鍟嗗搧鍚嶇О', width: 200}, - {field: 'batch', title: '鎵瑰彿'}, {field: 'specs', title: '瑙勬牸'}, + {field: 'weight', title: '閲嶉噺', edit: true}, {field: 'anfme', title: '鏁伴噺(淇敼)', style: 'color: blue;font-weight: bold', edit: true, minWidth: 110, width: 110}, - // {field: 'inQty', title: '宸插叆搴撻噺', minWidth: 100, width: 100}, - {field: 'unit', title: '鍗曚綅', width: 80}, + {field: 'owner', title: '璐т富缂栧彿', style: 'color: blue;font-weight: bold', edit: true, minWidth: 110, width: 110}, + {field: 'payment', title: '璐х墿鐘舵��', style: 'color: blue;font-weight: bold', templet: '#payment'}, + // {field: 'payment', title: '璐х墿鐘舵��',align: 'center', templet: '#payment'}, + {field: 'qty', 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) { - mlist= res.data - for (let i = 0; i < mlist.length; i++) { - var waitIn=mlist[i] - inQtys.push(waitIn.qty) - } + done: function (res, curr, count) { $(layero).find('.layui-table-view').css('margin', '0'); + var options = this; + + // 鑾峰彇褰撳墠琛屾暟鎹� + table.getRowData = function(elem){ + var index = $(elem).closest('tr').data('index'); + return table.cache[options.id][index] || {}; + }; + + $('.select-primary').on('change', function(){ + var value = this.value; // 鑾峰彇閫変腑椤� value + var data = table.getRowData(this); + console.log(value); + xxDataList.forEach(res => { + if (data.id === res.id){ + console.log(res) + res.payment = value; + } + }) + + + }); }, size: '' }; + if (!isExpAdd) { $.ajax({ url: baseUrl+"/order/detl/all/auth?orderId=" + expTpe.id, @@ -267,6 +382,10 @@ if (layEvent === 'edit') { showEditModel2(data); } else if (layEvent === 'del') { + if(data.workQty > 0){ + layer.msg("宸插瓨鍦ㄤ綔涓氭暟閲忥紝涓嶈兘鍒犻櫎", {icon: 2}); + return; + } layer.confirm('纭畾瑕佸垹闄ゅ悧锛�', { shade: .1, skin: 'layui-layer-admin' @@ -284,35 +403,32 @@ }); // 鏄庣粏鏁版嵁淇敼 table.on('edit(formSSXMTable)', function (obj) { - if (obj.field === 'memo'){ - for (let i=0;i<xxDataList.length;i++) { - if (xxDataList[i]["matnr"] === obj.data.matnr && xxDataList[i]["batch"] === obj.data.batch) { - xxDataList[i]["memo"] = obj.value; - break; - } - } - } else if (obj.field==='anfme'){ + let index = obj.tr.attr("data-index"); + let data = xxDataList[index]; + if (obj.field === 'anfme'){ let vle = Number(obj.value); if (isNaN(vle)) { layer.msg("璇疯緭鍏ユ暟瀛�", {icon: 2}); return false; } else { - if (vle > 0) { - for (let i=0;i<xxDataList.length;i++) { - if (xxDataList[i]["matnr"] === obj.data.matnr && xxDataList[i]["batch"] === obj.data.batch) { - xxDataList[i]["anfme"] = vle; - break; - } - } - } else { + if (vle <= 0) { layer.msg("鏁伴噺蹇呴』澶т簬闆�", {icon: 2}); + // data[obj.field] = 0; + // insTbSSXM.reload({data: xxDataList}); + return false; + } + if(obj.value < data.qty){ + layer.msg("杈撳叆鏁伴噺涓嶈兘灏忎簬浣滀笟涓暟閲�", {icon: 2}); + // data[obj.field] = 0; + // insTbSSXM.reload({data: xxDataList}); return false; } } } - insTbSSXM.reload({data: xxDataList}); + data[obj.field] = obj.value; + insTbSSXM.reloadData({data: xxDataList,scrollPos: true}); }); - // + $('#matAddBtnComment').click(function () { showEditModel2(); }); @@ -322,41 +438,34 @@ admin.open({ type: 1, offset: '150px', - area: '480px', + area: '680px', title: (exp ? '淇敼' : '娣诲姞') + '鏄庣粏', content: $('#matEditDialog').html(), success: function (layero, dIndex) { - $(layero).children('.layui-layer-content').css('overflow', 'visible'); // 鍥炴樉鏁版嵁 form.val('matEditForm', exp); // 琛ㄥ崟鎻愪氦浜嬩欢 form.on('submit(matEditSubmit)', function (data) { - var existMats = []; - xxDataList.forEach(function(elem) { - existMats.push(elem.matNo); - }); - var selectList = matXmSelect.getValue(); - for (var i = 0; i<selectList.length; i++) { - var item = selectList[i]; - if (existMats.indexOf(item.value) === -1) { - // 鏌ヨ鐗╂枡璇︽儏 - $.ajax({ - url: baseUrl+"/matCode/covert/"+item.value+"/auth", - headers: {'token': localStorage.getItem('token')}, - method: 'GET', - async: false, - success: function (res) { - if (res.code === 200){ - xxDataList.push(res.data); - insTbSSXM.reload({data: xxDataList, page: {curr: 1}}); - } else if (res.code === 403){ - top.location.href = baseUrl+"/"; - }else { - layer.msg(res.msg, {icon: 2}) - } + let selectList = matXmSelect.getValue(); + for (let i = 0; i<selectList.length; i++) { + let item = selectList[i]; + // 鏌ヨ鐗╂枡璇︽儏 + $.ajax({ + url: baseUrl+"/mat/covert/"+item.value+"/auth", + headers: {'token': localStorage.getItem('token')}, + method: 'GET', + async: false, + success: function (res) { + if (res.code === 200){ + xxDataList.push(res.data); + insTbSSXM.reload({data: xxDataList, page: {curr: 1}}); + } else if (res.code === 403){ + top.location.href = baseUrl+"/"; + }else { + layer.msg(res.msg, {icon: 2}) } - }) - } + } + }) } layer.close(dIndex); return false; @@ -399,29 +508,73 @@ } }); + + } + + // 鍒犻櫎鍗曟嵁 - function doDel(billNo) { + function doDel(orderId) { layer.confirm('纭畾瑕佸垹闄ゅ悧锛�', { shade: .1, skin: 'layui-layer-admin' }, function (i) { layer.close(i); layer.load(2); - $.ajax({ - url: baseUrl+"/waitMatin/delete/auth", + url: baseUrl+"/order/delete/auth", headers: {'token': localStorage.getItem('token')}, data: { - billNo: billNo + orderId: orderId }, - // contentType:'application/json;charset=UTF-8', method: 'POST', success: function (res) { layer.closeAll('loading'); if (res.code === 200){ - insTb.reload({page: {curr: 1}}); + if (insTbCount === 0) { + insTb.reload({page: {curr: 1}}); + } else { + $(".layui-laypage-btn")[0].click(); + } + layer.msg(res.msg, {icon: 1}); + } else if (res.code === 403){ + top.location.href = baseUrl+"/"; + }else { + layer.msg(res.msg, {icon: 2}); + } + } + }) + }); + } + + // 淇敼璁㈠崟鐘舵�� + function doModify(orderId, orderNo, settle) { + layer.confirm('纭畾瑕佹墜鍔ㄥ畬缁撳悧锛�', { + shade: .1, + skin: 'layui-layer-admin' + }, function (i) { + layer.close(i); + layer.load(2); + console.log(orderId); + console.log(settle); + $.ajax({ + url: baseUrl+"/order/update/auth", + headers: {'token': localStorage.getItem('token')}, + data: { + id: orderId, + orderNo: orderNo, + settle: settle + }, + method: 'POST', + success: function (res) { + layer.closeAll('loading'); + if (res.code === 200){ + if (insTbCount === 0) { + insTb.reload({page: {curr: 1}}); + } else { + $(".layui-laypage-btn")[0].click(); + } layer.msg(res.msg, {icon: 1}); } else if (res.code === 403){ top.location.href = baseUrl+"/"; @@ -438,4 +591,76 @@ ,type: 'datetime' ,range: true }); + + function printExcel(data){ + layer.confirm('纭畾瀵煎嚭Excel鍚�', {shadeClose: true}, function(){ + layer.closeAll(); + layer.load(1, {shade: [0.1,'#fff']}); + // location.href = "http://192.168.4.121:8082/stwms/orderCheck/printExport/auth?orderNo="+data.orderNo; + location.href = baseUrl+"/order/printExport/auth?orderNo="+data.orderNo; + layer.closeAll('loading'); + }); + } + + + function btnPrint2(orderId, orderNo, settle) { + console.log(orderId); + console.log(orderNo); + console.log(settle); + printMatCodeNos.push(orderNo) + var templateNo = 4; + $.ajax({ + url: baseUrl + "/order/print2/auth", + headers: {'token': localStorage.getItem('token')}, + data: {param: printMatCodeNos}, + method: 'POST', + async: false, + success: function (res) { + if (res.code === 200) { + layer.closeAll(); + var json = res; + + json.docNum = orderNo; + console.log("json"+json); + var sum = new Decimal("0"); + + + for (let i = 0; i < res.data.length; i++){ + sum = sum.plus(res.data[i].anfme); + + } + json.anfmeSum = sum; + var barcodeUrl = baseUrl + "/order/code/auth?type=1¶m=" + res.data[0].docNum; + console.log("barcodeUrl:"+barcodeUrl); + json.barcodeUrl = barcodeUrl; + console.log(json.data); + for (let i = 0; i < json.data.length; i++) { + var templateDom = $("#templatePreview" + templateNo); + var className = templateDom.attr("class"); + + if (className === 'template-barcode') { + json.data[i]["barcodeUrl"] = baseUrl + "/order/code/auth?type=2¶m=" + (json.data[i].orderNo+";"+json.data[i].matnr+";"); + } else { + json.data[i]["barcodeUrl"] = baseUrl + "/order/code/auth?type=2¶m=" + (json.data[i].orderNo+";"+json.data[i].matnr+";"); + } + } + var tpl = templateDom.html(); + var template = Handlebars.compile(tpl); + var html = template(json); + var box = $("#box"); + box.html(html); + box.show(); + box.print({mediaPrint: true}); + box.hide(); + } else if (json.code === 403) { + top.location.href = baseUrl + "/"; + } else { + layer.msg(json.msg) + } + } + }) + } + + + }); -- Gitblit v1.9.1