| var insTbCount = 0; | 
| var admin; | 
| var insTb | 
| layui.config({ | 
|     base: baseUrl + "/static/layui/lay/modules/" | 
| }).use(['layer', 'form', 'table', 'util', 'admin', 'xmSelect', 'laydate'], function () { | 
|     var $ = layui.jquery; | 
|     var layer = layui.layer; | 
|     var form = layui.form; | 
|     var table = layui.table; | 
|     var util = layui.util; | 
|     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}) | 
|             } | 
|         } | 
|     }) | 
|   | 
|     // 渲染表格 | 
|     insTb = table.render({ | 
|         elem: '#order', | 
|         url: baseUrl+'/orderLog/head/page/auth', | 
|         headers: {token: localStorage.getItem('token')}, | 
|         page: true, | 
|         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: '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: '创建时间', hide: true}, | 
|             {field: 'createBy$', title: '创建人'}, | 
|             {field: 'orderTime', align: 'center',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: '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}, | 
|         ]], | 
|         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 | 
|         }, | 
|         done: function (res, curr, count) { | 
|             limit(); | 
|             if (res.code === 403) { | 
|                 top.location.href = baseUrl+"/"; | 
|             } | 
|             insTbCount = count; | 
|         } | 
|     }); | 
|   | 
|     // 搜索 | 
|     form.on('submit(tbSearch)', function (data) { | 
|         insTb.reload({where: data.field, page: {curr: 1}}); | 
|     }); | 
|   | 
|     // 添加 | 
|     $("#orderAddBtn").click(function () { | 
|         showEditModel(); | 
|     }); | 
|   | 
|     // 导入销售单 | 
|     $("#importOrder").click(function () { | 
|         $("#importExcel").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(); | 
|             var top = offset.top; | 
|             var left = offset.left; | 
|             layer.open({ | 
|                 type: 1, | 
|                 title: false, | 
|                 area: '1460px', | 
|                 offset: [top + 'px', (left - 900 + $a.outerWidth()) + 'px'], | 
|                 shade: .01, | 
|                 shadeClose: true, | 
|                 fixed: false, | 
|                 content: '<table id="lookSSXMTable" lay-filter="lookSSXMTable"></table>', | 
|                 success: function (layero) { | 
|                     table.render({ | 
|                         elem: '#lookSSXMTable', | 
|                         headers: {token: localStorage.getItem('token')}, | 
|                         url: baseUrl+'/orderDetlLog/list/auth', | 
|                         where: { | 
|                             order_id: data.id | 
|                         }, | 
|                         page: true, | 
|                         cellMinWidth: 100, | 
|                         cols: [[ | 
|                             //{type: 'numbers'}, | 
|                             {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: 'createTime$', title: '创建时间', sort: true, templet: function (d) { | 
|                             //         return util.toDateString(d.createTime); | 
|                             //     },  width: 180 | 
|                             // }, | 
|                             // {field: 'inQty', title: '已入库量'}, | 
|                             // {field: 'color', 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', | 
|                             pageSize: 'limit' | 
|                         }, | 
|                         parseData: function (res) { | 
|                             return { | 
|                                 'code': res.code, | 
|                                 'msg': res.msg, | 
|                                 'count': res.data.total, | 
|                                 'data': res.data.records | 
|                             } | 
|                         }, | 
|                         response: { | 
|                             statusCode: 200 | 
|                         }, | 
|                         done: function () { | 
|                             $(layero).find('.layui-table-view').css('margin', '0'); | 
|                         }, | 
|                         size: '' | 
|                     }); | 
|                 } | 
|             }); | 
|         } | 
|     }); | 
|   | 
|   | 
|   | 
|     // 任务追溯 | 
|     function showWrkTrace(orderId) { | 
|         let loadIndex = layer.msg('请求中...', {icon: 16, shade: 0.01, time: false}); | 
|         $.ajax({ | 
|             url: baseUrl+"/orderLog/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 + "/orderLog/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 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}); | 
| } |