From 469d8ceb95ed82f09fd4c1bddbbe672689bc8d82 Mon Sep 17 00:00:00 2001 From: zhangc <zc@123> Date: 星期三, 09 四月 2025 19:52:22 +0800 Subject: [PATCH] 1 --- src/main/webapp/static/js/order/order.js | 494 ++++++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 404 insertions(+), 90 deletions(-) diff --git a/src/main/webapp/static/js/order/order.js b/src/main/webapp/static/js/order/order.js index c0b408b..0903332 100644 --- a/src/main/webapp/static/js/order/order.js +++ b/src/main/webapp/static/js/order/order.js @@ -1,4 +1,6 @@ var insTbCount = 0; +var admin; +var insTb layui.config({ base: baseUrl + "/static/layui/lay/modules/" }).use(['layer', 'form', 'table', 'util', 'admin', 'xmSelect', 'laydate'], function () { @@ -7,12 +9,34 @@ var form = layui.form; var table = layui.table; var util = layui.util; - var admin = layui.admin; + admin = layui.admin; var xmSelect = layui.xmSelect; var layDate = layui.laydate; + var laytpl = layui.laytpl; + + // 娓叉煋鎼滅储妯℃澘 + $.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({ + insTb = table.render({ elem: '#order', url: baseUrl+'/order/head/page/auth', headers: {token: localStorage.getItem('token')}, @@ -20,13 +44,26 @@ cellMinWidth: 100, cols: [[ {type: 'numbers'}, - {field: 'orderNo', title: '鍗曟嵁缂栧彿', sort: true}, - {field: 'docType$', align: 'center', title: '绫诲瀷', minWidth: 160, width: 160}, + {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: 'docType$', 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: 'createTime$', title: '鍒涘缓鏃堕棿', minWidth: 200, width: 200}, - {field: 'settle$', align: 'center', title: '鐘舵��', templet: '#settleTpl', 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: 140, width: 140}, {field: 'memo', align: 'center',title: '澶囨敞', hide: true}, - {align: 'center', title: '鎿嶄綔', toolbar: '#operate', minWidth: 130, width: 130} + {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}, + {align: 'center', title: '鎿嶄綔', toolbar: '#operate', width: 160} ]], request: { pageName: 'curr', @@ -44,6 +81,7 @@ statusCode: 200 }, done: function (res, curr, count) { + limit(); if (res.code === 403) { top.location.href = baseUrl+"/"; } @@ -61,14 +99,33 @@ showEditModel(); }); + // 瀵煎叆閿�鍞崟 + $("#importOrder").click(function () { + $("#importExcel").trigger("click"); + }); + // 瀵煎叆鍗婃垚鍝� + $("#importBcpOrder").click(function () { + $("#importBcpExcel").trigger("click"); + }); + + $("#orderCheckBtn").click(function () { + $("#importExcel2").trigger("click"); + }); + // 宸ュ叿鏉$偣鍑讳簨浠� table.on('tool(order)', function (obj) { var data = obj.data; var layEvent = obj.event; if (layEvent === 'edit') { showEditModel(data); + } else if (layEvent === 'wrkTrace') { + showWrkTrace(data.id); } else if (layEvent === 'del') { doDel(data.id); + } else if (layEvent === 'complete') { + doModify(data.id, 4); + } else if (layEvent === 'report'){ + doReport(data.id); } else if (layEvent === 'look') { var $a = $(obj.tr).find('a[lay-event="look"]'); var offset = $a.offset(); @@ -77,7 +134,7 @@ layer.open({ type: 1, title: false, - area: '800px', + area: '1100px', offset: [top + 'px', (left - 530 + $a.outerWidth()) + 'px'], shade: .01, shadeClose: true, @@ -95,12 +152,12 @@ cellMinWidth: 100, cols: [[ {type: 'numbers'}, - {field: 'matnr', title: '鍟嗗搧缂栫爜'}, - {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'}, - {field: 'unit', title: '鍗曚綅'}, + // {field: 'unit', title: '鍗曚綅'}, // { // field: 'createTime$', title: '鍒涘缓鏃堕棿', sort: true, templet: function (d) { // return util.toDateString(d.createTime); @@ -108,7 +165,15 @@ // }, // {field: 'inQty', title: '宸插叆搴撻噺'}, // {field: 'color', title: '棰滆壊'}, - {field: 'specs', title: '瑙勬牸'} + //{field: 'specs', title: '瑙勬牸鍨嬪彿'}, + {field: 'unit', 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', @@ -137,13 +202,11 @@ // 鏄剧ず琛ㄥ崟寮圭獥 function showEditModel(expTpe) { - var mlist=null - var inQtys=[] admin.open({ 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; @@ -161,27 +224,6 @@ } let nList = admin.util.deepClone(xxDataList); 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; @@ -221,27 +263,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: 'batch', title: '鎵瑰彿'}, + {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: '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'); + $(".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: '' }; @@ -286,37 +353,41 @@ }); } }); + // 宸ュ叿鏉$偣鍑讳簨浠� + 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) { - 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 = 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); 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}); return false; } } } + data[obj.field] = obj.value; insTbSSXM.reload({data: xxDataList}); }); - // + $('#matAddBtnComment').click(function () { showEditModel2(); }); @@ -326,41 +397,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; @@ -439,9 +503,259 @@ }); } + // 涓婁紶瀹℃牳鍗曟嵁 + function doReport(orderId) { + layer.confirm('纭畾瑕佷笂浼犲崟鎹悧锛�', { + shade: .1, + skin: 'layui-layer-admin' + }, function (i) { + layer.close(i); + layer.load(2); + $.ajax({ + url: baseUrl+"/order/report/auth", + headers: {'token': localStorage.getItem('token')}, + data: { + orderId: orderId + }, + 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+"/"; + }else { + layer.msg(res.msg, {icon: 2}); + } + } + }) + }); + } + + // 淇敼璁㈠崟鐘舵�� + function doModify(orderId, 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, + 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+"/"; + }else { + layer.msg(res.msg, {icon: 2}); + } + } + }) + }); + } + + // 浠诲姟杩芥函 + function showWrkTrace(orderId) { + let loadIndex = layer.msg('璇锋眰涓�...', {icon: 16, shade: 0.01, time: false}); + $.ajax({ + url: baseUrl+"/order/wrk/trace/auth", + headers: {'token': localStorage.getItem('token')}, + data: { + orderId: orderId + }, + method: 'POST', + success: function (res) { + layer.close(loadIndex); + if (res.code === 200){ + laytpl(wrkTraceDialog.innerHTML).render(res.data, function (html) { + admin.open({ + type: 1, + title: '浠诲姟杩芥函', + area: ['800px', '450px'], + shadeClose: true, + content: html, + success: function (layero, dIndex) { + $(layero).children('.layui-layer-content').css('overflow', 'visible'); + /** 缁熻鍥捐〃 */ + var traceCharts = echarts.init(document.getElementById('wrkTraceCharts')); + var traceOptions = { + title: { + text: '浣滀笟/鎬婚噺', x: 'center', y: '38%', + textStyle: {fontSize: 18, color: '#262626', fontWeight: 'normal'}, + subtextStyle: {fontSize: 36, color: '#10B4E8'}, + itemGap: 20 + }, + color: ['#10B4E8', '#E0E0E0', '#FF0000'], + tooltip: {trigger: 'item'}, + series: [{name: '鏁伴噺', type: 'pie', radius: ['75%', '80%'], label: {normal: {show: false}}}] + }; + traceCharts.setOption(traceOptions); + // 璧嬪�� + traceCharts.setOption({ + title: { + subtext: res.data.wrkQty+"/"+res.data.totalQty + }, + series: [ + { + data: [ + {name: '宸蹭綔涓�', value: res.data.wrkQty}, + {name: '鏈綔涓�', value: res.data.totalQty-res.data.wrkQty-res.data.lackQty}, + {name: '搴撳瓨涓嶈冻', value: res.data.lackQty}, + ] + } + ] + }); + } + }); + }); + } else if (res.code === 403){ + top.location.href = baseUrl+"/"; + }else { + layer.msg(res.msg, {icon: 2}); + } + } + }) + } + + layDate.render({ elem: '.layui-laydate-range' ,type: 'datetime' ,range: true }); }); + +function upload(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/import/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 upload3(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/import3/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}); +} + + +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