| | |
| | | var insTbCount = 0; |
| | | layui.config({ |
| | | var insTb; |
| | | var insLookTb; |
| | | layui.config({ |
| | | base: baseUrl + "/static/layui/lay/modules/" |
| | | }).use(['layer', 'form', 'table', 'util', 'admin', 'xmSelect', 'laydate'], function () { |
| | | var $ = layui.jquery; |
| | |
| | | var xmSelect = layui.xmSelect; |
| | | var layDate = layui.laydate; |
| | | var laytpl = layui.laytpl; |
| | | var dateIns = layDate.render({ |
| | | elem: '#modi_time' |
| | | ,type: 'datetime' |
| | | ,range: true |
| | | ,lang: typeof I18n !== 'undefined' && I18n.getLanguage().toLowerCase() === 'zh-cn' ? 'cn' : 'en' |
| | | }); |
| | | function getCols() { |
| | | return [[ |
| | | {type: 'numbers'}, |
| | | {field: 'orderNo', title: I18n.t('order_no'), templet: '#orderNoTpl'}, |
| | | {field: 'docType$', align: 'center', title: I18n.t('doc_type'), minWidth: 160, width: 160, templet: function (d) { |
| | | return I18n.t(d.docType$); |
| | | }}, |
| | | {align: 'center', title: I18n.t('order_detail'), toolbar: '#tbLook', minWidth: 160, width: 160}, |
| | | {field: 'createTime$', title: I18n.t('create_time'), minWidth: 200, width: 200}, |
| | | {field: 'settle$', align: 'center', title: I18n.t('status'), templet: '#settleTpl', minWidth: 160, width: 160}, |
| | | {field: 'memo', align: 'center',title: I18n.t('memo'), hide: true}, |
| | | {align: 'center', title: I18n.t('operation'), toolbar: '#operate', width: 180} |
| | | ]]; |
| | | } |
| | | |
| | | function getLookCols() { |
| | | return [[ |
| | | {type: 'numbers'}, |
| | | {field: 'matnr', title: I18n.t('mat_code'), width: 160}, |
| | | {field: 'maktx', title: I18n.t('mat_name'), width: 160}, |
| | | {field: 'batch', title: I18n.t('batch')}, |
| | | {field: 'anfme', title: I18n.t('quantity')}, |
| | | {field: 'workQty', title: I18n.t('work_qty')}, |
| | | {field: 'qty', title: I18n.t('finish_qty'), 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: I18n.t('spec')} |
| | | ]]; |
| | | } |
| | | |
| | | function getFormCols() { |
| | | return [[ |
| | | {type: 'numbers', title: '#'}, |
| | | {field: 'matnr', title: I18n.t('mat_code'), width: 160}, |
| | | {field: 'maktx', title: I18n.t('mat_name'), width: 200}, |
| | | {field: 'batch', title: I18n.t('batch'), edit: true}, |
| | | {field: 'specs', title: I18n.t('spec')}, |
| | | {field: 'anfme', title: I18n.t('quantity') + '(' + I18n.t('modify') + ')', style: 'color: blue;font-weight: bold', edit: true, minWidth: 110, width: 110}, |
| | | {field: 'workQty', title: I18n.t('work_qty'), minWidth: 100, width: 100}, |
| | | // {field: 'unit', title: '单位', width: 80}, |
| | | {field: 'memo', title: I18n.t('memo') , edit: true}, |
| | | {align: 'center', title: I18n.t('operation'), toolbar: '#formSSXMTableBar', minWidth: 80, width: 80, fixed: 'right'} |
| | | ]]; |
| | | } |
| | | |
| | | // 渲染搜索模板 |
| | | var docTypeData = null; |
| | | function renderDocTypeSelect() { |
| | | if (!docTypeData || !docTypeData.records) return; |
| | | |
| | | layui.each(docTypeData.records, function(index, item){ |
| | | item.transDocName = I18n.t(item.docName$ || item.docName); |
| | | }); |
| | | |
| | | var template = Handlebars.compile($('#docTypeTpl').html()); |
| | | $('#docType-query').html(template(docTypeData)); |
| | | I18n.updatePage($('#docType-query')); |
| | | layui.form.render('select'); |
| | | } |
| | | |
| | | $.ajax({ |
| | | url: baseUrl+"/docType/list/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | |
| | | 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'); |
| | | docTypeData = res.data; |
| | | renderDocTypeSelect(); |
| | | } else if (res.code === 403){ |
| | | top.location.href = baseUrl+"/"; |
| | | } else { |
| | |
| | | }) |
| | | |
| | | // 渲染表格 |
| | | var insTb = table.render({ |
| | | elem: '#order', |
| | | url: baseUrl+'/order/head/page/auth', |
| | | headers: {token: localStorage.getItem('token')}, |
| | | page: true, |
| | | cellMinWidth: 100, |
| | | cols: [[ |
| | | {type: 'numbers'}, |
| | | {field: 'orderNo', title: '单据编号', templet: '#orderNoTpl'}, |
| | | {field: 'docType$', align: 'center', title: '类型', minWidth: 160, width: 160}, |
| | | {align: 'center', title: '明细', toolbar: '#tbLook', minWidth: 160, width: 160}, |
| | | {field: 'createTime$', title: '创建时间', minWidth: 200, width: 200}, |
| | | {field: 'settle$', align: 'center', title: '状态', templet: '#settleTpl', minWidth: 160, width: 160}, |
| | | {field: 'memo', align: 'center',title: '备注', hide: true}, |
| | | {align: 'center', title: '操作', toolbar: '#operate', width: 180} |
| | | ]], |
| | | request: { |
| | | pageName: 'curr', |
| | | pageSize: 'limit' |
| | | }, |
| | | parseData: function (res) { |
| | | return { |
| | | 'code': res.code, |
| | | 'msg': res.msg, |
| | | 'count': res.data.total, |
| | | 'data': res.data.records |
| | | function initTable() { |
| | | insTb = table.render({ |
| | | elem: '#order', |
| | | url: baseUrl+'/order/head/page/auth', |
| | | headers: {token: localStorage.getItem('token')}, |
| | | page: true, |
| | | cellMinWidth: 100, |
| | | cols: getCols(), |
| | | 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; |
| | | if (typeof I18n !== 'undefined' && I18n.isReady()) { |
| | | I18n.updatePage(); |
| | | I18n.updateLayuiPagination(); |
| | | } |
| | | if (typeof dateIns !== 'undefined') { |
| | | // Completely remove and recreate the input element to force laydate reset |
| | | var $input = $('#modi_time'); |
| | | var parent = $input.parent(); |
| | | var inputHtml = $input.prop("outerHTML"); |
| | | $input.remove(); |
| | | parent.append(inputHtml); |
| | | $('#modi_time').removeAttr('lay-key'); // Ensure no key remains |
| | | |
| | | dateIns = layDate.render({ |
| | | elem: '#modi_time' |
| | | ,type: 'datetime' |
| | | ,range: true |
| | | ,lang: I18n.getLanguage().toLowerCase() === 'zh-cn' ? 'cn' : 'en' |
| | | }); |
| | | } |
| | | }, |
| | | response: { |
| | | statusCode: 200 |
| | | }, |
| | | done: function (res, curr, count) { |
| | | limit(); |
| | | if (res.code === 403) { |
| | | top.location.href = baseUrl+"/"; |
| | | } |
| | | insTbCount = count; |
| | | }); |
| | | } |
| | | |
| | | if (typeof I18n !== 'undefined' && I18n.isReady()) { |
| | | initTable(); |
| | | } else { |
| | | $(document).on('i18n:ready', initTable); |
| | | } |
| | | |
| | | // 监听语言切换 |
| | | $(document).on('i18n:languageChanged', function () { |
| | | renderDocTypeSelect(); |
| | | insTb.reload({ |
| | | cols: getCols() |
| | | }); |
| | | if (insLookTb && $('#lookSSXMTable').length > 0) { |
| | | insLookTb.reload({ |
| | | cols: getLookCols() |
| | | }); |
| | | } |
| | | }); |
| | | |
| | |
| | | fixed: false, |
| | | content: '<table id="lookSSXMTable" lay-filter="lookSSXMTable"></table>', |
| | | success: function (layero) { |
| | | table.render({ |
| | | insLookTb = table.render({ |
| | | elem: '#lookSSXMTable', |
| | | headers: {token: localStorage.getItem('token')}, |
| | | url: baseUrl+'/orderDetl/list/auth', |
| | |
| | | }, |
| | | page: true, |
| | | cellMinWidth: 100, |
| | | cols: [[ |
| | | {type: 'numbers'}, |
| | | {field: 'matnr', title: '商品编码', width: 160}, |
| | | {field: 'maktx', title: '商品名称', width: 160}, |
| | | {field: 'batch', title: '批号'}, |
| | | {field: 'anfme', title: '数量'}, |
| | | {field: 'workQty', 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: '规格'} |
| | | ]], |
| | | cols: getLookCols(), |
| | | request: { |
| | | pageName: 'curr', |
| | | pageSize: 'limit' |
| | |
| | | statusCode: 200 |
| | | }, |
| | | done: function () { |
| | | I18n.updateLayuiPagination(); |
| | | $(layero).find('.layui-table-view').css('margin', '0'); |
| | | }, |
| | | size: '' |
| | |
| | | function showEditModel(expTpe) { |
| | | admin.open({ |
| | | type: 1, |
| | | title: (expTpe ? '修改' : '添加') + '单据', |
| | | title: (expTpe ? I18n.t('modify_order') : I18n.t('add_order')), |
| | | content: $('#editDialog').html(), |
| | | area: '1300px', |
| | | success: function (layero, dIndex) { |
| | | I18n.updatePage($(layero)); |
| | | $(layero).children('.layui-layer-content').css('overflow', 'visible'); |
| | | var isExpAdd = !expTpe; |
| | | // 回显数据 |
| | |
| | | form.on('submit(orderEditSubmit)', function (data) { |
| | | // 组装数据 |
| | | if (xxDataList.length <= 0) { |
| | | layer.tips('请添加单据明细', '#matAddBtnComment', {tips: [1, '#ff4c4c']}); |
| | | layer.tips(I18n.t('please_add_detail_first'), '#matAddBtnComment', {tips: [1, '#ff4c4c']}); |
| | | return false; |
| | | } |
| | | let nList = admin.util.deepClone(xxDataList); |
| | | for (let xi = 0; xi < nList.length; xi++) { |
| | | if (nList[xi].anfme <= 0){ |
| | | layer.msg('明细修改数量不合法', {icon: 2}); |
| | | layer.msg(I18n.t('detail_modify_qty_invalid'), {icon: 2}); |
| | | return false; |
| | | } |
| | | if (nList[xi].anfme < nList[xi].workQty){ |
| | | layer.msg('数量不能小于已作业数量', {icon: 2}); |
| | | layer.msg(I18n.t('qty_cannot_less_than_worked'), {icon: 2}); |
| | | return false; |
| | | } |
| | | } |
| | |
| | | if (res.code === 200){ |
| | | layer.close(dIndex); |
| | | $(".layui-laypage-btn")[0].click(); |
| | | layer.msg(res.msg, {icon: 1}); |
| | | layer.msg(typeof I18n !== 'undefined' ? I18n.t(res.msg) : res.msg, {icon: 1}); |
| | | } else if (res.code === 403){ |
| | | top.location.href = baseUrl+"/"; |
| | | }else { |
| | |
| | | page: true, |
| | | height: '350px;', |
| | | cellMinWidth: 100, |
| | | cols: [[ |
| | | {type: 'numbers', title: '#'}, |
| | | {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: 'workQty', 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'} |
| | | ]], |
| | | cols: getFormCols(), |
| | | done: function (res) { |
| | | $(layero).find('.layui-table-view').css('margin', '0'); |
| | | }, |
| | |
| | | showEditModel2(data); |
| | | } else if (layEvent === 'del') { |
| | | if(data.workQty > 0){ |
| | | layer.msg("已存在作业数量,不能删除", {icon: 2}); |
| | | layer.msg(I18n.t('work_qty_exists_cannot_delete'), {icon: 2}); |
| | | return; |
| | | } |
| | | layer.confirm('确定要删除吗?', { |
| | | layer.confirm(I18n.t('confirm_delete_data'), { |
| | | shade: .1, |
| | | skin: 'layui-layer-admin' |
| | | }, function (i) { |
| | |
| | | if (obj.field === 'anfme'){ |
| | | let vle = Number(obj.value); |
| | | if (isNaN(vle)) { |
| | | layer.msg("请输入数字", {icon: 2}); |
| | | layer.msg(I18n.t('please_enter_number'), {icon: 2}); |
| | | return false; |
| | | } else { |
| | | if (vle <= 0) { |
| | | layer.msg("数量必须大于零", {icon: 2}); |
| | | layer.msg(I18n.t('quantity_must_be_greater_than_zero'), {icon: 2}); |
| | | // data[obj.field] = 0; |
| | | // insTbSSXM.reload({data: xxDataList}); |
| | | return false; |
| | | } |
| | | if(obj.value < data.workQty){ |
| | | layer.msg("输入数量不能小于作业中数量", {icon: 2}); |
| | | layer.msg(I18n.t('input_qty_cannot_less_than_working'), {icon: 2}); |
| | | // data[obj.field] = 0; |
| | | // insTbSSXM.reload({data: xxDataList}); |
| | | return false; |
| | |
| | | type: 1, |
| | | offset: '150px', |
| | | area: '680px', |
| | | title: (exp ? '修改' : '添加') + '明细', |
| | | title: (exp ? I18n.t('modify_detail') : I18n.t('add_detail')), |
| | | content: $('#matEditDialog').html(), |
| | | success: function (layero, dIndex) { |
| | | // 回显数据 |
| | |
| | | // 渲染物料选择 |
| | | var matXmSelect = xmSelect.render({ |
| | | el: '#mat', |
| | | language: (typeof I18n !== 'undefined' && localStorage.getItem('lang') === 'en') ? 'en' : 'zn', |
| | | tips: typeof I18n !== 'undefined' ? I18n.t('please_select') : '请选择', |
| | | searchTips: typeof I18n !== 'undefined' ? I18n.t('search') : '搜索', |
| | | style: { |
| | | width: '340px', |
| | | }, |
| | | autoRow: true, |
| | | collapse: true, |
| | | toolbar: { show: true }, |
| | | filterable: true, |
| | | remoteSearch: true, |
| | |
| | | } |
| | | }) |
| | | // 弹窗不出现滚动条 |
| | | I18n.updatePage($(layero)); |
| | | $(layero).children('.layui-layer-content').css('overflow', 'visible'); |
| | | layui.form.render('select'); |
| | | } |
| | |
| | | |
| | | // 删除单据 |
| | | function doDel(orderId) { |
| | | layer.confirm('确定要删除吗?', { |
| | | layer.confirm(I18n.t('confirm_delete'), { |
| | | shade: .1, |
| | | skin: 'layui-layer-admin' |
| | | }, function (i) { |
| | |
| | | } else { |
| | | $(".layui-laypage-btn")[0].click(); |
| | | } |
| | | layer.msg(res.msg, {icon: 1}); |
| | | layer.msg(typeof I18n !== 'undefined' ? I18n.t(res.msg) : res.msg, {icon: 1}); |
| | | } else if (res.code === 403){ |
| | | top.location.href = baseUrl+"/"; |
| | | }else { |
| | |
| | | |
| | | // 修改订单状态 |
| | | function doModify(orderId, orderNo, settle) { |
| | | layer.confirm('确定要手动完结吗?', { |
| | | layer.confirm(I18n.t('confirm_manual_complete'), { |
| | | shade: .1, |
| | | skin: 'layui-layer-admin' |
| | | }, function (i) { |
| | |
| | | } else { |
| | | $(".layui-laypage-btn")[0].click(); |
| | | } |
| | | layer.msg(res.msg, {icon: 1}); |
| | | layer.msg(typeof I18n !== 'undefined' ? I18n.t(res.msg) : res.msg, {icon: 1}); |
| | | } else if (res.code === 403){ |
| | | top.location.href = baseUrl+"/"; |
| | | }else { |
| | |
| | | |
| | | // 任务追溯 |
| | | function showWrkTrace(orderId) { |
| | | let loadIndex = layer.msg('请求中...', {icon: 16, shade: 0.01, time: false}); |
| | | let loadIndex = layer.msg(I18n.t('requesting'), {icon: 16, shade: 0.01, time: false}); |
| | | $.ajax({ |
| | | url: baseUrl+"/order/wrk/trace/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | |
| | | laytpl(wrkTraceDialog.innerHTML).render(res.data, function (html) { |
| | | admin.open({ |
| | | type: 1, |
| | | title: '任务追溯', |
| | | title: I18n.t('wrk_trace'), |
| | | area: ['800px', '450px'], |
| | | shadeClose: true, |
| | | content: html, |
| | | success: function (layero, dIndex) { |
| | | $(layero).children('.layui-layer-content').css('overflow', 'visible'); |
| | | /** 统计图表 */ |
| | | I18n.updatePage($(layero)); |
| | | $(layero).children('.layui-layer-content').css('overflow', 'visible'); |
| | | /** 统计图表 */ |
| | | var traceCharts = echarts.init(document.getElementById('wrkTraceCharts')); |
| | | var traceOptions = { |
| | | title: { |
| | | text: '总量/作业/完成', x: 'center', y: '38%', |
| | | text: I18n.t('trace_chart_title'), 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}}}] |
| | | series: [{name: I18n.t('quantity'), type: 'pie', radius: ['75%', '80%'], label: {normal: {show: false}}}] |
| | | }; |
| | | traceCharts.setOption(traceOptions); |
| | | // 赋值 |
| | |
| | | series: [ |
| | | { |
| | | data: [ |
| | | {name: '已作业', value: res.data.wrkQty}, |
| | | {name: '未作业', value: res.data.totalQty-res.data.wrkQty-res.data.lackQty}, |
| | | {name: '库存不足', value: res.data.lackQty}, |
| | | {name: I18n.t('worked'), value: res.data.wrkQty}, |
| | | {name: I18n.t('not_worked'), value: res.data.totalQty-res.data.wrkQty-res.data.lackQty}, |
| | | {name: I18n.t('stock_shortage'), value: res.data.lackQty}, |
| | | ] |
| | | } |
| | | ] |