|  |  | 
 |  |  |         cellMinWidth: 100, | 
 |  |  |         cols: [[ | 
 |  |  |             {type: 'numbers'}, | 
 |  |  |             {field: 'defNumber', align: 'center', title: '操作系统号', hide: false, width: 120}, | 
 |  |  |             {field: '操作单据', align: 'center', title: '操作单据', hide: true}, | 
 |  |  |             {field: '操作类型', align: 'center', title: '操作类型', hide: true}, | 
 |  |  |             {field: 'orderNo', title: '单据编号', templet: '#orderNoTpl'}, | 
 |  |  |             {field: 'docType$', align: 'center', title: '类型',  minWidth: 160, width: 160}, | 
 |  |  |             {field: 'postFee', align: 'center', title: '总数量',  minWidth: 130, width: 130}, | 
 |  |  |             //{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: 'createTime$', title: '创建时间'}, | 
 |  |  |             {field: 'shipCode', align: 'center',title: '制单人', hide: false}, | 
 |  |  |             {field: 'settle$', align: 'center', title: '状态', templet: '#settleTpl',  minWidth: 160, width: 160}, | 
 |  |  |             {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}, | 
 |  |  |  | 
 |  |  |             {align: 'center', title: '操作', toolbar: '#operate', width: 180} | 
 |  |  |         ]], | 
 |  |  |         request: { | 
 |  |  | 
 |  |  |         $("#importExcel").trigger("click"); | 
 |  |  |     }); | 
 |  |  |  | 
 |  |  |      $("#orderCheckBtn").click(function () { | 
 |  |  |             $("#importExcel2").trigger("click"); | 
 |  |  |         }); | 
 |  |  |  | 
 |  |  |     // 工具条点击事件 | 
 |  |  |     table.on('tool(order)', function (obj) { | 
 |  |  |         var data = obj.data; | 
 |  |  | 
 |  |  |             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(); | 
 |  |  | 
 |  |  |             layer.open({ | 
 |  |  |                 type: 1, | 
 |  |  |                 title: false, | 
 |  |  |                 area: '820px', | 
 |  |  |                 offset: [top + 'px', (left - 530 + $a.outerWidth()) + 'px'], | 
 |  |  |                 area: '1460px', | 
 |  |  |                 offset: [top + 'px', (left - 900 + $a.outerWidth()) + 'px'], | 
 |  |  |                 shade: .01, | 
 |  |  |                 shadeClose: true, | 
 |  |  |                 fixed: false, | 
 |  |  | 
 |  |  |                         cellMinWidth: 100, | 
 |  |  |                         cols: [[ | 
 |  |  |                             {type: 'numbers'}, | 
 |  |  |                             {field: 'matnr', title: '物料号', width: 160}, | 
 |  |  |                             {field: 'maktx', title: '物料名称', width: 160}, | 
 |  |  |                             {field: 'batch', title: '序列码'}, | 
 |  |  |                             {field: 'matnr', title: '商品编码', width: 160}, | 
 |  |  |                             {field: 'maktx', title: '商品名称', width: 160}, | 
 |  |  |                             //{field: 'batch', title: '批号'}, | 
 |  |  |                             {field: 'anfme', title: '数量'}, | 
 |  |  |                             {field: 'qty', title: '作业数量', style: 'font-weight: bold'}, | 
 |  |  |                             // {field: 'unit', title: '单位'}, | 
 |  |  | 
 |  |  |                             // }, | 
 |  |  |                             // {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: '工序'} | 
 |  |  |                         ]], | 
 |  |  |                         request: { | 
 |  |  |                             pageName: 'curr', | 
 |  |  | 
 |  |  |             type: 1, | 
 |  |  |             title: (expTpe ? '修改' : '添加') + '单据', | 
 |  |  |             content: $('#editDialog').html(), | 
 |  |  |             area: '1300px', | 
 |  |  |             area: '1600px', | 
 |  |  |             success: function (layero, dIndex) { | 
 |  |  |                 console.log(expTpe) | 
 |  |  |                 $(layero).children('.layui-layer-content').css('overflow', 'visible'); | 
 |  |  |                 var isExpAdd = !expTpe; | 
 |  |  |                 // 回显数据 | 
 |  |  | 
 |  |  |                     page: true, | 
 |  |  |                     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: 200}, | 
 |  |  |                         {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: true, minWidth: 110, width: 110}, | 
 |  |  |                         {field: 'deadTime', title: '销售订单行号(修改)', style: 'color: blue;font-weight: bold', edit: true, minWidth: 110, width: 110}, | 
 |  |  |                         {field: 'processSts', title: '工序', templet: function (d) { | 
 |  |  |                                 console.log(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) { | 
 |  |  |                         console.log(res) | 
 |  |  |                         $(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) { | 
 |  |  |                             console.log(item) | 
 |  |  |                             var elem = $(item); | 
 |  |  |                             elem.val(elem.data('state')).parents('div.layui-table-cell').css('overflow', 'visible'); | 
 |  |  |                         }); | 
 |  |  |  | 
 |  |  |                         form.render();//刷新表单 | 
 |  |  |                     }, | 
 |  |  |                     size: '' | 
 |  |  |                 }; | 
 |  |  | 
 |  |  |                             } | 
 |  |  |                             insTbSSXM.reload({data: xxDataList, page: {curr: 1}}); | 
 |  |  |                         }); | 
 |  |  |                     } | 
 |  |  |                 }); | 
 |  |  |                 // 工具条点击事件 | 
 |  |  |                 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 | 
 |  |  |                         } | 
 |  |  |                     } | 
 |  |  |                 }); | 
 |  |  |                 // 明细数据修改 | 
 |  |  | 
 |  |  |             layer.load(2); | 
 |  |  |             $.ajax({ | 
 |  |  |                 url: baseUrl+"/order/delete/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 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 | 
 |  |  | 
 |  |  |     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}); | 
 |  |  | } |