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: '
', 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}); }