|  |  | 
 |  |  | var pageCurr; | 
 |  |  |  | 
 |  |  | var locDetlData = []; | 
 |  |  | function getCol() { | 
 |  |  |     var cols = [ | 
 |  |  |         {field: 'count', align: 'center',title: '出库数量', edit:'text', width: 130,  style:'color: blue;font-weight: bold'} | 
 |  |  |         ,{field: 'anfme', align: 'center',title: '原数量'} | 
 |  |  |         ,{field: 'locNo$', align: 'center',title: '库位号'} | 
 |  |  |     ]; | 
 |  |  |     arrRemove(detlCols,  'field', 'anfme'); | 
 |  |  |     cols.push.apply(cols, detlCols); | 
 |  |  |     cols.push({fixed: 'right', title:'操作', align: 'center', toolbar: '#operate', width:80}) | 
 |  |  |     return cols; | 
 |  |  | } | 
 |  |  |  | 
 |  |  | layui.use(['table','laydate', 'form'], function() { | 
 |  |  |     var table = layui.table; | 
 |  |  |     var $ = layui.jquery; | 
 |  |  |     var layer = layui.layer; | 
 |  |  |     var layDate = layui.laydate; | 
 |  |  |     var form = layui.form; | 
 |  |  |  | 
 |  |  |     // 数据渲染 | 
 |  |  |     tableIns = table.render({ | 
 |  |  |         elem: '#stockOut', | 
 |  |  |         elem: '#chooseData', | 
 |  |  |         headers: {token: localStorage.getItem('token')}, | 
 |  |  |         url: baseUrl+'/locDetl/list/auth', | 
 |  |  |         page: true, | 
 |  |  |         limit: 10, | 
 |  |  |         skin: 'line', | 
 |  |  |         data: [], | 
 |  |  |         even: true, | 
 |  |  |         toolbar: '#toolbar', | 
 |  |  |         cellMinWidth: 50, | 
 |  |  |         cols: [[ | 
 |  |  |             {type: 'checkbox'} | 
 |  |  |             ,{field: 'locNo$', align: 'center',title: '库位号'} | 
 |  |  |             ,{field: 'matnr', align: 'center',title: '物料'} | 
 |  |  |             ,{field: 'lgnum', align: 'center',title: '仓库号', width:80} | 
 |  |  |             ,{field: 'tbnum', align: 'center',title: '转储请求编号'} | 
 |  |  |             // ,{field: 'tbpos', align: 'center',title: '行项目'} | 
 |  |  |             ,{field: 'zmatid', align: 'center',title: '物料标签ID', width:200} | 
 |  |  |             ,{field: 'maktx', align: 'center',title: '物料描述', width:150} | 
 |  |  |             ,{field: 'werks', align: 'center',title: '工厂'} | 
 |  |  |             ,{field: 'anfme', align: 'center',title: '数量', width:80} | 
 |  |  |             ,{field: 'altme', align: 'center',title: '单位', width:80} | 
 |  |  |             ,{field: 'zpallet', align: 'center',title: '托盘条码'} | 
 |  |  |             ,{field: 'bname', align: 'center',title: '用户ID'} | 
 |  |  |             // ,{field: 'memo', align: 'center',title: '备注'} | 
 |  |  |  | 
 |  |  |         ]], | 
 |  |  |         request: { | 
 |  |  |             pageName: 'curr', | 
 |  |  |             pageSize: 'limit' | 
 |  |  |         }, | 
 |  |  |         parseData: function (res) { | 
 |  |  |             return { | 
 |  |  |                 'code': res.code, | 
 |  |  |                 'msg': res.msg, | 
 |  |  |                 'count': res.data.total, | 
 |  |  |                 'data': res.data.records | 
 |  |  |             } | 
 |  |  |         }, | 
 |  |  |         response: { | 
 |  |  |             statusCode: 200 | 
 |  |  |         }, | 
 |  |  |         cols: [getCol()], | 
 |  |  |         done: function(res, curr, count) { | 
 |  |  |             if (res.code === 403) { | 
 |  |  |                 top.location.href = baseUrl+"/"; | 
 |  |  |             } | 
 |  |  |             pageCurr=curr; | 
 |  |  |             limit(); | 
 |  |  |             form.on('checkbox(tableCheckbox)', function (data) { | 
 |  |  |                 var _index = $(data.elem).attr('table-index')||0; | 
 |  |  |                 if(data.elem.checked){ | 
 |  |  |                     res.data[_index][data.value] = 'Y'; | 
 |  |  |                 }else{ | 
 |  |  |                     res.data[_index][data.value] = 'N'; | 
 |  |  |                 } | 
 |  |  |             }); | 
 |  |  |             getOutBound(); | 
 |  |  |         } | 
 |  |  |     }); | 
 |  |  |  | 
 |  |  |     // 监听排序事件 | 
 |  |  |     table.on('sort(locDetl)', function (obj) { | 
 |  |  |         var searchData = {}; | 
 |  |  |         $.each($('#search-box [name]').serializeArray(), function() { | 
 |  |  |             searchData[this.name] = this.value; | 
 |  |  |         }); | 
 |  |  |         searchData['orderByField'] = obj.field; | 
 |  |  |         searchData['orderByType'] = obj.type; | 
 |  |  |         tableIns.reload({ | 
 |  |  |             where: searchData, | 
 |  |  |             page: { | 
 |  |  |                 curr: 1 | 
 |  |  |             }, | 
 |  |  |             done: function (res, curr, count) { | 
 |  |  |                 if (res.code === 403) { | 
 |  |  |                     top.location.href = baseUrl+"/"; | 
 |  |  |     // 页面修改 | 
 |  |  |     table.on('edit(chooseData)', function (obj) { | 
 |  |  |         updateLocDetlData(obj.data.locNo, obj.data.matnr, Number(obj.value)); | 
 |  |  |     }); | 
 |  |  |  | 
 |  |  |     // 监听头工具栏事件 | 
 |  |  |     table.on('toolbar(chooseData)', function (obj) { | 
 |  |  |         var data = locDetlData; | 
 |  |  |         switch (obj.event) { | 
 |  |  |             case 'outbound': | 
 |  |  |                 if (data.length === 0){ | 
 |  |  |                     layer.msg('请先添加库位物料'); | 
 |  |  |                 } else { | 
 |  |  |                     var staNo = $("#staNoSelect").val(); | 
 |  |  |                     if (staNo === "" || staNo === null){ | 
 |  |  |                         layer.msg("请选择出库口"); | 
 |  |  |                         return; | 
 |  |  |                     } | 
 |  |  |                     var locDetls = []; | 
 |  |  |                     data.forEach(function(elem) { | 
 |  |  |                         locDetls.push({locNo: elem.locNo, matnr: elem.matnr, count: elem.count}); | 
 |  |  |                     }); | 
 |  |  |                     let param = { | 
 |  |  |                         outSite: staNo, | 
 |  |  |                         locDetls: locDetls | 
 |  |  |                     } | 
 |  |  |                     $.ajax({ | 
 |  |  |                         url: baseUrl+"/plate/out/start", | 
 |  |  |                         headers: {'token': localStorage.getItem('token')}, | 
 |  |  |                         data: JSON.stringify(param), | 
 |  |  |                         contentType:'application/json;charset=UTF-8', | 
 |  |  |                         method: 'POST', | 
 |  |  |                         success: function (res) { | 
 |  |  |                             if (res.code === 200){ | 
 |  |  |                                 locDetlData = []; | 
 |  |  |                                 tableIns.reload({data: locDetlData,done:function (res) {limit();getOutBound();}}); | 
 |  |  |                                 layer.msg(res.msg); | 
 |  |  |                             } else if (res.code === 403){ | 
 |  |  |                                 top.location.href = baseUrl+"/"; | 
 |  |  |                             } else { | 
 |  |  |                                 layer.msg(res.msg) | 
 |  |  |                             } | 
 |  |  |                         } | 
 |  |  |                     }); | 
 |  |  |                 } | 
 |  |  |                 pageCurr=curr; | 
 |  |  |                 limit(); | 
 |  |  |                 break; | 
 |  |  |         } | 
 |  |  |     }); | 
 |  |  |  | 
 |  |  |     // 监听行工具事件 | 
 |  |  |     table.on('tool(chooseData)', function(obj){ | 
 |  |  |         var data = obj.data; | 
 |  |  |         switch (obj.event) { | 
 |  |  |             case 'remove': | 
 |  |  |                 for (var i = locDetlData.length - 1; i >= 0; i--) { | 
 |  |  |                     if (locDetlData[i].locNo === data.locNo && locDetlData[i].matnr === data.matnr) { | 
 |  |  |                         locDetlData.splice(i, 1); | 
 |  |  |                     } | 
 |  |  |                 } | 
 |  |  |                 tableIns.reload({data: locDetlData,done:function (res) {limit();getOutBound();}}); | 
 |  |  |                 break; | 
 |  |  |         } | 
 |  |  |     }); | 
 |  |  |  | 
 |  |  |     function updateLocDetlData(locNo, matnr, count) { | 
 |  |  |         if (isNaN(count)) { | 
 |  |  |             layer.msg("请输入数字"); | 
 |  |  |         } else { | 
 |  |  |             if (count > 0) { | 
 |  |  |                 for (var i=0;i<locDetlData.length;i++){ | 
 |  |  |                     if (locDetlData[i]["locNo"] === locNo && locDetlData[i]["matnr"] === matnr){ | 
 |  |  |                         if (count > locDetlData[i]["anfme"]) { | 
 |  |  |                             layer.msg("不能超过原数量"); | 
 |  |  |                         } else { | 
 |  |  |                             locDetlData[i]["count"] = count; | 
 |  |  |                         } | 
 |  |  |                         break; | 
 |  |  |                     } | 
 |  |  |                 } | 
 |  |  |             } else { | 
 |  |  |                 layer.msg("数量必须大于零"); | 
 |  |  |             } | 
 |  |  |         }); | 
 |  |  |     }); | 
 |  |  |  | 
 |  |  |     // 搜索栏搜索事件 | 
 |  |  |     form.on('submit(search)', function (data) { | 
 |  |  |         pageCurr = 1; | 
 |  |  |         tableReload(); | 
 |  |  |         getOutBound(); | 
 |  |  |     }); | 
 |  |  |  | 
 |  |  |     // 搜索栏重置事件 | 
 |  |  |     form.on('submit(reset)', function (data) { | 
 |  |  |         pageCurr = 1; | 
 |  |  |         clearFormVal($('#search-box')); | 
 |  |  |         tableReload(); | 
 |  |  |         getOutBound(); | 
 |  |  |     }); | 
 |  |  |         } | 
 |  |  |         tableIns.reload({data: locDetlData,done:function (res) {limit(); getOutBound();}}); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     // 获取出库口 | 
 |  |  |     function getOutBound(){ | 
 |  |  | 
 |  |  |     } | 
 |  |  | }) | 
 |  |  |  | 
 |  |  |  | 
 |  |  | function tableReload(child) { | 
 |  |  |     var searchData = {}; | 
 |  |  |     $.each($('#search-box [name]').serializeArray(), function() { | 
 |  |  |         searchData[this.name] = this.value; | 
 |  |  |     }); | 
 |  |  |     (child ? parent.tableIns : tableIns).reload({ | 
 |  |  |         where: searchData, | 
 |  |  |         page: { | 
 |  |  |             curr: pageCurr | 
 |  |  |         }, | 
 |  |  |         done: function (res, curr, count) { | 
 |  |  |             if (res.code === 403) { | 
 |  |  |                 top.location.href = baseUrl+"/"; | 
 |  |  |             } | 
 |  |  |             pageCurr=curr; | 
 |  |  |             if (res.data.length === 0 && count !== 0) { | 
 |  |  |                 tableIns.reload({ | 
 |  |  |                     where: searchData, | 
 |  |  |                     page: { | 
 |  |  |                         curr: pageCurr-1 | 
 |  |  |                     } | 
 |  |  |                 }); | 
 |  |  |                 pageCurr -= 1; | 
 |  |  |             } | 
 |  |  |             limit(child); | 
 |  |  | // 提取物料 | 
 |  |  | var locDetlLayerIdx; | 
 |  |  | function getLocDetl() { | 
 |  |  |     locDetlLayerIdx = layer.open({ | 
 |  |  |         type: 2, | 
 |  |  |         title: '提取出货内容', | 
 |  |  |         maxmin: true, | 
 |  |  |         area: [top.detailWidth, top.detailHeight], | 
 |  |  |         shadeClose: true, | 
 |  |  |         content: 'locDetlQuery.html', | 
 |  |  |         success: function(layero, index){ | 
 |  |  |         } | 
 |  |  |     }); | 
 |  |  | } | 
 |  |  |  | 
 |  |  | // 添加表格数据 | 
 |  |  | function addTableData(data) { | 
 |  |  |     for (var i=0;i<data.length;i++){ | 
 |  |  |         let pass = false; | 
 |  |  |         for (var j=0;j<locDetlData.length;j++){ | 
 |  |  |             if (data[i].matnr === locDetlData[j].matnr && data[i].locNo$ === locDetlData[j].locNo$) { | 
 |  |  |                 pass = true; | 
 |  |  |                 break; | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |         if (pass) { | 
 |  |  |             data.splice(i--, 1); | 
 |  |  |         } else { | 
 |  |  |             data[i]["count"] = data[i]["anfme"]; | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |     } | 
 |  |  |     locDetlData.push.apply(locDetlData, data); | 
 |  |  |     tableIns.reload({data: locDetlData}); | 
 |  |  |     layer.close(locDetlLayerIdx); | 
 |  |  | } |