|  |  |  | 
|---|
|  |  |  | {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: '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: 'enableQty', align: 'center',title: '待出数量', style: 'font-weight: bold'} | 
|---|
|  |  |  | ,{field: 'threeCode', align: 'center',title: '销售订单号'} | 
|---|
|  |  |  | ,{field: 'deadTime', align: 'center',title: '销售订单行号'} | 
|---|
|  |  |  | // ,{field: 'name', align: 'center',title: '名称'} | 
|---|
|  |  |  | // ,{field: 'model', align: 'center',title: '型号'} | 
|---|
|  |  |  | // ,{field: 'model', align: 'center',title: '通用型号'} | 
|---|
|  |  |  | ,{field: 'unit', align: 'center',title: '单位', hide: true} | 
|---|
|  |  |  | ,{field: 'barcode', align: 'center',title: '商品条码', hide: true} | 
|---|
|  |  |  | // ,{field: 'supplier', align: 'center',title: '供应商'} | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 表格2头工具栏点击事件 */ | 
|---|
|  |  |  | table.on('toolbar(orderDetlTable)', function (obj) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var checkStatus = table.checkStatus(obj.config.id).data; | 
|---|
|  |  |  | if (obj.event === 'pakoutPreview') { // 添加 | 
|---|
|  |  |  | if (checkStatus.length === 0) { | 
|---|
|  |  |  | 
|---|
|  |  |  | method: 'POST', | 
|---|
|  |  |  | success: function (res) { | 
|---|
|  |  |  | layer.close(loadIndex); | 
|---|
|  |  |  | var tableCache; | 
|---|
|  |  |  | if (res.code === 200){ | 
|---|
|  |  |  | layer.open({ | 
|---|
|  |  |  | type: 1 | 
|---|
|  |  |  | ,title: false | 
|---|
|  |  |  | ,closeBtn: false | 
|---|
|  |  |  | ,offset: '50px' | 
|---|
|  |  |  | ,area: ['1200px', '700px'] | 
|---|
|  |  |  | ,shade: 0.5 | 
|---|
|  |  |  | ,shadeClose: false | 
|---|
|  |  |  | ,btn: ['立即出库', '稍后处理'] | 
|---|
|  |  |  | ,btnAlign: 'c' | 
|---|
|  |  |  | ,moveType: 1 //拖拽模式,0或者1 | 
|---|
|  |  |  | ,content: $('#pakoutPreviewBox').html() | 
|---|
|  |  |  | ,success: function(layero, index){ | 
|---|
|  |  |  | stoPreTabIdx = table.render({ | 
|---|
|  |  |  | elem: '#stoPreTab', | 
|---|
|  |  |  | data: res.data, | 
|---|
|  |  |  | height: 520, | 
|---|
|  |  |  | page: false, | 
|---|
|  |  |  | 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'}, | 
|---|
|  |  |  | {field: 'locNo', title: '货位', align: 'center', width: 100, templet: '#locNoTpl'}, | 
|---|
|  |  |  | {field: 'staNos', align: 'center', title: '出库站', merge: ['locNo'], templet: '#tbBasicTbStaNos'}, | 
|---|
|  |  |  | // {type: 'checkbox', merge: ['locNo']}, | 
|---|
|  |  |  | ]], | 
|---|
|  |  |  | done: function (res) { | 
|---|
|  |  |  | tableMerge.render(this); | 
|---|
|  |  |  | $('.layui-table-body.layui-table-main').css("overflow", "auto"); | 
|---|
|  |  |  | tableCache = tableData = table.cache.stoPreTab; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 修改出库站 | 
|---|
|  |  |  | form.on('select(tbBasicTbStaNos)', function (obj) { | 
|---|
|  |  |  | let index  = obj.othis.parents('tr').attr("data-index"); | 
|---|
|  |  |  | let data = tableCache[index]; | 
|---|
|  |  |  | for (let i = 0; i<tableCache.length; i++) { | 
|---|
|  |  |  | if (tableCache[i].locNo === data.locNo) { | 
|---|
|  |  |  | tableCache[i]['staNo'] = Number(obj.elem.value); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | obj.othis.children().find("input").css("color", "blue"); | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 批量修改出库站 | 
|---|
|  |  |  | form.on('submit(batchModifySta)', function () { | 
|---|
|  |  |  | modifySta(); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 批量修改出库站 - 站点选择 | 
|---|
|  |  |  | function modifySta() { | 
|---|
|  |  |  | // 出库站取交集 | 
|---|
|  |  |  | let staBatchSelectVal = []; | 
|---|
|  |  |  | for(let i = 0; i<tableCache.length; i++) { | 
|---|
|  |  |  | let staNos = tableCache[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, | 
|---|
|  |  |  | area: '300px', | 
|---|
|  |  |  | offset: 'auto', | 
|---|
|  |  |  | title: '请选择站点', | 
|---|
|  |  |  | content: $('#staBatchSelectDialog').html(), | 
|---|
|  |  |  | success: function (layero, ddIndex) { | 
|---|
|  |  |  | // 渲染下拉框 | 
|---|
|  |  |  | let template = Handlebars.compile($('#batchStaSelectTpl').html()); | 
|---|
|  |  |  | $('#batchSelectStaBox').html(template({list: staBatchSelectVal})); | 
|---|
|  |  |  | // 确认 | 
|---|
|  |  |  | form.on('submit(staBatchSelectConfirm)', function (obj) { | 
|---|
|  |  |  | let loadIdx = layer.load(2); | 
|---|
|  |  |  | let batchSta = Number(obj.field.batchSta); | 
|---|
|  |  |  | let arr = []; | 
|---|
|  |  |  | for (let i = 0; i<tableCache.length; i++) { | 
|---|
|  |  |  | tableCache[i]['staNo'] = batchSta; | 
|---|
|  |  |  | arr.push(i); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | stoPreTabIdx.reload({data: tableCache}); | 
|---|
|  |  |  | arr.forEach(item => { | 
|---|
|  |  |  | $('div[lay-id=stoPreTab] tr[data-index="' + item + '"] .order-sta-select').val(batchSta); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | layui.form.render('select'); | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 弹窗不出现滚动条 | 
|---|
|  |  |  | $(layero).children('.layui-layer-content').css('overflow', 'visible'); | 
|---|
|  |  |  | layui.form.render('select'); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ,yes: function(index, layero){ | 
|---|
|  |  |  | //按钮【立即出库】的回调 | 
|---|
|  |  |  | pakout(tableCache, index); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ,btn2: function(index, layero){ | 
|---|
|  |  |  | //按钮【稍后处理】的回调 | 
|---|
|  |  |  | layer.close(index) | 
|---|
|  |  |  | //return false 开启该代码可禁止点击该按钮关闭 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | pakoutPreviewDialog(res.data) | 
|---|
|  |  |  | } else if (res.code === 403){ | 
|---|
|  |  |  | top.location.href = baseUrl+"/"; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function pakoutPreviewDialog(data) { | 
|---|
|  |  |  | for(var i=0; i<data.length; i++){ | 
|---|
|  |  |  | if(!data[i].staNos){ | 
|---|
|  |  |  | data[i].staNos = data[i].agvStaNos; | 
|---|
|  |  |  | data[i].staNo = data[i].agvStaNo; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var tableCache; | 
|---|
|  |  |  | layer.open({ | 
|---|
|  |  |  | type: 1 | 
|---|
|  |  |  | ,title: false | 
|---|
|  |  |  | ,closeBtn: false | 
|---|
|  |  |  | ,offset: '50px' | 
|---|
|  |  |  | ,area: ['1200px', '700px'] | 
|---|
|  |  |  | ,shade: 0.5 | 
|---|
|  |  |  | ,shadeClose: false | 
|---|
|  |  |  | ,btn: ['立即出库', '稍后处理'] | 
|---|
|  |  |  | ,btnAlign: 'c' | 
|---|
|  |  |  | ,moveType: 1 //拖拽模式,0或者1 | 
|---|
|  |  |  | ,content: $('#pakoutPreviewBox').html() | 
|---|
|  |  |  | ,success: function(layero, index){ | 
|---|
|  |  |  | stoPreTabIdx = table.render({ | 
|---|
|  |  |  | elem: '#stoPreTab', | 
|---|
|  |  |  | data: data, | 
|---|
|  |  |  | height: 520, | 
|---|
|  |  |  | page: false, | 
|---|
|  |  |  | 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'}, | 
|---|
|  |  |  | {field: 'locNo', title: '货位', align: 'center', templet: '#locNoTpl'}, | 
|---|
|  |  |  | {field: 'staNos', align: 'center', title: '出库站', merge: ['locNo'], templet: '#tbBasicTbStaNos'}, | 
|---|
|  |  |  | // {type: 'checkbox', merge: ['locNo']}, | 
|---|
|  |  |  | ]], | 
|---|
|  |  |  | //cols: getCol(data), | 
|---|
|  |  |  | done: function (res) { | 
|---|
|  |  |  | tableMerge.render(this); | 
|---|
|  |  |  | $('.layui-table-body.layui-table-main').css("overflow", "auto"); | 
|---|
|  |  |  | tableCache = tableData = table.cache.stoPreTab; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 修改出库站 | 
|---|
|  |  |  | form.on('select(tbBasicTbStaNos)', function (obj) { | 
|---|
|  |  |  | let index  = obj.othis.parents('tr').attr("data-index"); | 
|---|
|  |  |  | let data = tableCache[index]; | 
|---|
|  |  |  | for (let i = 0; i<tableCache.length; i++) { | 
|---|
|  |  |  | if (tableCache[i].locNo === data.locNo) { | 
|---|
|  |  |  | //tableCache[i]['staNo'] = Number(obj.elem.value); | 
|---|
|  |  |  | tableCache[i]['staNo'] = obj.elem.value; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | obj.othis.children().find("input").css("color", "blue"); | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 批量修改出库站 | 
|---|
|  |  |  | form.on('submit(batchModifySta)', function () { | 
|---|
|  |  |  | modifySta(); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 批量修改出库站 - 站点选择 | 
|---|
|  |  |  | function modifySta() { | 
|---|
|  |  |  | // 出库站取交集 | 
|---|
|  |  |  | let staBatchSelectVal = []; | 
|---|
|  |  |  | for(let i = 0; i<tableCache.length; i++) { | 
|---|
|  |  |  | let staNos = tableCache[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, | 
|---|
|  |  |  | area: '300px', | 
|---|
|  |  |  | offset: 'auto', | 
|---|
|  |  |  | title: '请选择站点', | 
|---|
|  |  |  | content: $('#staBatchSelectDialog').html(), | 
|---|
|  |  |  | success: function (layero, ddIndex) { | 
|---|
|  |  |  | // 渲染下拉框 | 
|---|
|  |  |  | let template = Handlebars.compile($('#batchStaSelectTpl').html()); | 
|---|
|  |  |  | $('#batchSelectStaBox').html(template({list: staBatchSelectVal})); | 
|---|
|  |  |  | // 确认 | 
|---|
|  |  |  | form.on('submit(staBatchSelectConfirm)', function (obj) { | 
|---|
|  |  |  | let loadIdx = layer.load(2); | 
|---|
|  |  |  | //let batchSta = Number(obj.field.batchSta); | 
|---|
|  |  |  | let batchSta = obj.field.batchSta; | 
|---|
|  |  |  | let arr = []; | 
|---|
|  |  |  | for (let i = 0; i<tableCache.length; i++) { | 
|---|
|  |  |  | tableCache[i]['staNo'] = batchSta; | 
|---|
|  |  |  | arr.push(i); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | stoPreTabIdx.reload({data: tableCache}); | 
|---|
|  |  |  | arr.forEach(item => { | 
|---|
|  |  |  | $('div[lay-id=stoPreTab] tr[data-index="' + item + '"] .order-sta-select').val(batchSta); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | layui.form.render('select'); | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 弹窗不出现滚动条 | 
|---|
|  |  |  | $(layero).children('.layui-layer-content').css('overflow', 'visible'); | 
|---|
|  |  |  | layui.form.render('select'); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ,yes: function(index, layero){ | 
|---|
|  |  |  | //按钮【立即出库】的回调 | 
|---|
|  |  |  | pakout(tableCache, index); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ,btn2: function(index, layero){ | 
|---|
|  |  |  | //按钮【稍后处理】的回调 | 
|---|
|  |  |  | layer.close(index) | 
|---|
|  |  |  | //return false 开启该代码可禁止点击该按钮关闭 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function pakout(tableCache, layerIndex) { | 
|---|
|  |  |  | // let loadIndex = layer.load(2); | 
|---|
|  |  |  | for(var i=0; i<tableCache.length; i++){ | 
|---|
|  |  |  | if(tableCache[i].agvStaNos){ | 
|---|
|  |  |  | tableCache[i].agvStaNo = tableCache[i].staNo; | 
|---|
|  |  |  | tableCache[i].staNos = null; | 
|---|
|  |  |  | tableCache[i].staNo = null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | notice.msg('正在生成出库任务......', {icon: 4}); | 
|---|
|  |  |  | $.ajax({ | 
|---|
|  |  |  | url: baseUrl + "/out/pakout/auth", | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | window.pakoutPreview = pakoutPreview; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // ---------------------------------------------------------------------------------------------------------------------------------- | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 合并出库 | 
|---|
|  |  |  | form.on('submit(mergeOut)', function (data) { | 
|---|
|  |  |  | let checkStatus = layui.table.checkStatus('originTable').data; | 
|---|
|  |  |  | 
|---|
|  |  |  | success: function (res) { | 
|---|
|  |  |  | layer.close(loadIndex); | 
|---|
|  |  |  | if (res.code === 200){ | 
|---|
|  |  |  | admin.open({ | 
|---|
|  |  |  | type: 1, | 
|---|
|  |  |  | title: '订单合并 【 数量:' + orderIds.length + " 】", | 
|---|
|  |  |  | content: $('#mergeDialog').html(), | 
|---|
|  |  |  | area: '900px', | 
|---|
|  |  |  | success: function (layero, dIndex) { | 
|---|
|  |  |  | $('#newOrderNo').val(res.data.newOrderNo); | 
|---|
|  |  |  | // 渲染客户列表 | 
|---|
|  |  |  | let cstmrVal = xmSelect.render({ | 
|---|
|  |  |  | el: '#cstmrSelect', | 
|---|
|  |  |  | radio: true, | 
|---|
|  |  |  | clickClose: true, | 
|---|
|  |  |  | filterable: true, | 
|---|
|  |  |  | create: function(val, arr){ | 
|---|
|  |  |  | if(arr.length === 0){ | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | name:  val, | 
|---|
|  |  |  | value: val | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | model: { | 
|---|
|  |  |  | icon: 'hidden', | 
|---|
|  |  |  | label: { | 
|---|
|  |  |  | type: 'text', | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | data: res.data.cstmrs | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | // 渲染明细 | 
|---|
|  |  |  | let xxDataList = res.data.orderDetls; | 
|---|
|  |  |  | let tbOptions = { | 
|---|
|  |  |  | elem: '#mergeTable', | 
|---|
|  |  |  | headers: {token: localStorage.getItem('token')}, | 
|---|
|  |  |  | data: xxDataList, | 
|---|
|  |  |  | limit: 9999, | 
|---|
|  |  |  | height: '350px;', | 
|---|
|  |  |  | layer.open({ | 
|---|
|  |  |  | type: 1 | 
|---|
|  |  |  | , title: false | 
|---|
|  |  |  | , closeBtn: false | 
|---|
|  |  |  | , offset: '50px' | 
|---|
|  |  |  | , area: ['1200px', '700px'] | 
|---|
|  |  |  | , shade: 0.5 | 
|---|
|  |  |  | , shadeClose: false | 
|---|
|  |  |  | , btn: ['确定', '取消'] | 
|---|
|  |  |  | , btnAlign: 'c' | 
|---|
|  |  |  | , moveType: 1 //拖拽模式,0或者1 | 
|---|
|  |  |  | , content: $('#mergeDialog').html() | 
|---|
|  |  |  | , success: function (layero, index) { | 
|---|
|  |  |  | orderMergeTabIdx = table.render({ | 
|---|
|  |  |  | elem: '#orderMergeTab', | 
|---|
|  |  |  | data: res.data, | 
|---|
|  |  |  | height: 550, | 
|---|
|  |  |  | page: false, | 
|---|
|  |  |  | limit: Number.MAX_VALUE, | 
|---|
|  |  |  | cellMinWidth: 100, | 
|---|
|  |  |  | cols: [[ | 
|---|
|  |  |  | {type: 'numbers', title: '#'}, | 
|---|
|  |  |  | {field: 'matnr', title: '商品编码', minWidth: 170}, | 
|---|
|  |  |  | {field: 'maktx', title: '商品名称'}, | 
|---|
|  |  |  | {field: 'batch', title: '批号'}, | 
|---|
|  |  |  | {field: 'anfme', title: '数量', minWidth: 80, width: 80}, | 
|---|
|  |  |  | {field: 'unitPrice', title: '单价(修改)', style: 'color: blue;font-weight: bold', edit: true, minWidth: 120, width: 120, fixed: 'right'}, | 
|---|
|  |  |  | // {align: 'center', title: '操作', toolbar: '#formSSXMTableBar', minWidth: 80, width: 80} | 
|---|
|  |  |  | {type: 'checkbox'}, | 
|---|
|  |  |  | {field: 'matnr', title: '物料号', align: 'center', width: 350}, | 
|---|
|  |  |  | {field: 'maktx', title: '物料名称', align: 'center'}, | 
|---|
|  |  |  | {field: 'specs', title: '规格', align: 'center'}, | 
|---|
|  |  |  | {field: 'batch', title: '批号', align: 'center'}, | 
|---|
|  |  |  | {field: 'anfme', title: '数量', align: 'center', width: 90, style: 'font-weight: bold'}, | 
|---|
|  |  |  | ]], | 
|---|
|  |  |  | done: function (res) { | 
|---|
|  |  |  | $(layero).find('.layui-table-view').css('margin', '0'); | 
|---|
|  |  |  | $('.layui-table-body.layui-table-main').css("overflow", "auto"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | let insMergeTb = table.render(tbOptions); | 
|---|
|  |  |  | // 价格修改 | 
|---|
|  |  |  | table.on('edit(mergeTable)', function (obj) { | 
|---|
|  |  |  | let unitPrice = Number(obj.value); | 
|---|
|  |  |  | if (isNaN(unitPrice)) { | 
|---|
|  |  |  | layer.msg("请输入数字", {icon: 2}); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | if (unitPrice > 0) { | 
|---|
|  |  |  | for (let i=0;i<xxDataList.length;i++){ | 
|---|
|  |  |  | if (xxDataList[i]["matnr"] === obj.data.matnr && xxDataList[i]["batch"] === obj.data.batch){ | 
|---|
|  |  |  | xxDataList[i]["unitPrice"] = unitPrice; | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | layer.msg("数量必须大于零", {icon: 2}); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | insMergeTb.reload({data: xxDataList}); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 合并表单提交事件 | 
|---|
|  |  |  | form.on('submit(mergeSubmit)', function (data) { | 
|---|
|  |  |  | let nList = admin.util.deepClone(xxDataList); | 
|---|
|  |  |  | data.field.cstmr = cstmrVal.getValue()[0] ? cstmrVal.getValue()[0].name : null; | 
|---|
|  |  |  | layer.load(2); | 
|---|
|  |  |  | $.ajax({ | 
|---|
|  |  |  | url: baseUrl+"/delivery/merge/auth", | 
|---|
|  |  |  | headers: {'token': localStorage.getItem('token')}, | 
|---|
|  |  |  | data: JSON.stringify({ | 
|---|
|  |  |  | oldOrderIds: orderIds, | 
|---|
|  |  |  | orderNo: data.field.newOrderNo, | 
|---|
|  |  |  | cstmr: data.field.cstmr, | 
|---|
|  |  |  | orderDetls: nList | 
|---|
|  |  |  | }), | 
|---|
|  |  |  | contentType:'application/json;charset=UTF-8', | 
|---|
|  |  |  | method: 'POST', | 
|---|
|  |  |  | success: function (res) { | 
|---|
|  |  |  | layer.closeAll('loading'); | 
|---|
|  |  |  | if (res.code === 200){ | 
|---|
|  |  |  | layer.close(dIndex); | 
|---|
|  |  |  | $(".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}); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | $(layero).children('.layui-layer-content').css('overflow', 'visible'); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | , yes: function (index, layero) { | 
|---|
|  |  |  | //按钮【确定】的回调 | 
|---|
|  |  |  | let checkStatus = layui.table.checkStatus('orderMergeTab').data; | 
|---|
|  |  |  | if (checkStatus.length < 1) { | 
|---|
|  |  |  | layer.msg("请至少选择一条数据", {icon: 7}); | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | let loadIndex = layer.load(2); | 
|---|
|  |  |  | $.ajax({ | 
|---|
|  |  |  | url: baseUrl + "/out/pakout/preview/merge/auth", | 
|---|
|  |  |  | headers: {'token': localStorage.getItem('token')}, | 
|---|
|  |  |  | contentType: 'application/json;charset=UTF-8', | 
|---|
|  |  |  | data: JSON.stringify(checkStatus), | 
|---|
|  |  |  | method: 'POST', | 
|---|
|  |  |  | success: function (res) { | 
|---|
|  |  |  | layer.close(loadIndex); | 
|---|
|  |  |  | if (res.code === 200){ | 
|---|
|  |  |  | layer.close(index) | 
|---|
|  |  |  | pakoutPreviewMergeDialog(res.data) | 
|---|
|  |  |  | } else if (res.code === 403){ | 
|---|
|  |  |  | top.location.href = baseUrl+"/"; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | layer.msg(res.msg, {icon: 2}) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | , btn2: function (index, layero) { | 
|---|
|  |  |  | //按钮【取消】的回调 | 
|---|
|  |  |  | layer.close(index) | 
|---|
|  |  |  | //return false 开启该代码可禁止点击该按钮关闭 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } else if (res.code === 403){ | 
|---|
|  |  |  | top.location.href = baseUrl+"/"; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function pakoutPreviewMergeDialog(data) { | 
|---|
|  |  |  | for(var i=0; i<data.length; i++){ | 
|---|
|  |  |  | if(!data[i].staNos){ | 
|---|
|  |  |  | data[i].staNos = data[i].agvStaNos; | 
|---|
|  |  |  | data[i].staNo = data[i].agvStaNo; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var mergeTabCache; | 
|---|
|  |  |  | layer.open({ | 
|---|
|  |  |  | type: 1 | 
|---|
|  |  |  | ,title: false | 
|---|
|  |  |  | ,closeBtn: false | 
|---|
|  |  |  | ,offset: '50px' | 
|---|
|  |  |  | ,area: ['1200px', '700px'] | 
|---|
|  |  |  | ,shade: 0.5 | 
|---|
|  |  |  | ,shadeClose: false | 
|---|
|  |  |  | ,btn: ['立即出库', '稍后处理'] | 
|---|
|  |  |  | ,btnAlign: 'c' | 
|---|
|  |  |  | ,moveType: 1 //拖拽模式,0或者1 | 
|---|
|  |  |  | ,content: $('#pakoutPreviewMergeBox').html() | 
|---|
|  |  |  | ,success: function(layero, index){ | 
|---|
|  |  |  | stoPreTabMergeIdx = table.render({ | 
|---|
|  |  |  | elem: '#stoPreTabMerge', | 
|---|
|  |  |  | data: data, | 
|---|
|  |  |  | height: 520, | 
|---|
|  |  |  | page: false, | 
|---|
|  |  |  | limit: Number.MAX_VALUE, | 
|---|
|  |  |  | cellMinWidth: 100, | 
|---|
|  |  |  | cols: [[ | 
|---|
|  |  |  | // {type: 'checkbox', merge: ['orderNo']}, | 
|---|
|  |  |  | {field: 'title', title: '商品', merge: true, align: 'center', width: 350}, | 
|---|
|  |  |  | {field: 'specs', title: '规格', align: 'center'}, | 
|---|
|  |  |  | {field: 'batch', title: '序列码', align: 'center'}, | 
|---|
|  |  |  | {field: 'anfme', title: '数量', align: 'center', width: 90, style: 'font-weight: bold'}, | 
|---|
|  |  |  | {field: 'locNo', title: '货位', align: 'center', templet: '#locNoTpl'}, | 
|---|
|  |  |  | {field: 'staNos', align: 'center', title: '出库站', merge: ['locNo'], templet: '#tbBasicTbStaNos'}, | 
|---|
|  |  |  | // {type: 'checkbox', merge: ['locNo']}, | 
|---|
|  |  |  | ]], | 
|---|
|  |  |  | done: function (res) { | 
|---|
|  |  |  | tableMerge.render(this); | 
|---|
|  |  |  | $('.layui-table-body.layui-table-main').css("overflow", "auto"); | 
|---|
|  |  |  | mergeTabCache = table.cache.stoPreTabMerge; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 修改出库站 | 
|---|
|  |  |  | form.on('select(tbBasicTbStaNos)', function (obj) { | 
|---|
|  |  |  | let index  = obj.othis.parents('tr').attr("data-index"); | 
|---|
|  |  |  | let data = mergeTabCache[index]; | 
|---|
|  |  |  | for (let i = 0; i<mergeTabCache.length; i++) { | 
|---|
|  |  |  | if (mergeTabCache[i].locNo === data.locNo) { | 
|---|
|  |  |  | //mergeTabCache[i]['staNo'] = Number(obj.elem.value); | 
|---|
|  |  |  | mergeTabCache[i]['staNo'] = obj.elem.value; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | obj.othis.children().find("input").css("color", "blue"); | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 批量修改出库站 | 
|---|
|  |  |  | form.on('submit(batchModifySta)', function () { | 
|---|
|  |  |  | modifySta(); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 批量修改出库站 - 站点选择 | 
|---|
|  |  |  | function modifySta() { | 
|---|
|  |  |  | // 出库站取交集 | 
|---|
|  |  |  | let staBatchSelectVal = []; | 
|---|
|  |  |  | for(let i = 0; i<mergeTabCache.length; i++) { | 
|---|
|  |  |  | let staNos = mergeTabCache[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, | 
|---|
|  |  |  | area: '300px', | 
|---|
|  |  |  | offset: 'auto', | 
|---|
|  |  |  | title: '请选择站点', | 
|---|
|  |  |  | content: $('#staBatchSelectDialog').html(), | 
|---|
|  |  |  | success: function (layero, ddIndex) { | 
|---|
|  |  |  | // 渲染下拉框 | 
|---|
|  |  |  | let template = Handlebars.compile($('#batchStaSelectTpl').html()); | 
|---|
|  |  |  | $('#batchSelectStaBox').html(template({list: staBatchSelectVal})); | 
|---|
|  |  |  | // 确认 | 
|---|
|  |  |  | form.on('submit(staBatchSelectConfirm)', function (obj) { | 
|---|
|  |  |  | let loadIdx = layer.load(2); | 
|---|
|  |  |  | //let batchSta = Number(obj.field.batchSta); | 
|---|
|  |  |  | let batchSta = obj.field.batchSta; | 
|---|
|  |  |  | let arr = []; | 
|---|
|  |  |  | for (let i = 0; i<mergeTabCache.length; i++) { | 
|---|
|  |  |  | mergeTabCache[i]['staNo'] = batchSta; | 
|---|
|  |  |  | arr.push(i); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | console.log(mergeTabCache) | 
|---|
|  |  |  | stoPreTabMergeIdx.reload({data: mergeTabCache}); | 
|---|
|  |  |  | arr.forEach(item => { | 
|---|
|  |  |  | $('div[lay-id=stoPreTabMerge] tr[data-index="' + item + '"] .order-sta-select').val(batchSta); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | layui.form.render('select'); | 
|---|
|  |  |  | arr.forEach(item => { | 
|---|
|  |  |  | $('div[lay-id=stoPreTabMerge] tr[data-index="' + item + '"] .layui-select-title').find("input").css("color", "blue"); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | layer.close(loadIdx); layer.close(ddIndex); | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 弹窗不出现滚动条 | 
|---|
|  |  |  | $(layero).children('.layui-layer-content').css('overflow', 'visible'); | 
|---|
|  |  |  | layui.form.render('select'); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ,yes: function(index, layero){ | 
|---|
|  |  |  | //按钮【立即出库】的回调 | 
|---|
|  |  |  | pakout(mergeTabCache, index); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ,btn2: function(index, layero){ | 
|---|
|  |  |  | //按钮【稍后处理】的回调 | 
|---|
|  |  |  | layer.close(index) | 
|---|
|  |  |  | //return false 开启该代码可禁止点击该按钮关闭 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|