自动化立体仓库 - WMS系统
lty
昨天 daac5618fc2322620a82d25603c5b4d15465c5ef
src/main/webapp/static/js/order/order.js
@@ -1,196 +1,465 @@
var pageCurr;
var insTbCount = 0;
var insTb;
var insLookTb;
function generateInspectionOrderNo(buyerCode) {
    var now = new Date();
    var year = String(now.getFullYear()).slice(-2);
    var code = (buyerCode || '').toUpperCase();
    var seq = String(now.getTime() % 100000).padStart(5, '0');
    return 'INS' + year + code + '/' + seq;
}
layui.config({
    base: baseUrl + "/static/layui/lay/modules/"
}).use(['table','laydate', 'form', 'admin'], function(){
    var table = layui.table;
}).use(['layer', 'form', 'table', 'util', 'admin', 'xmSelect', 'laydate'], function () {
    var $ = layui.jquery;
    var layer = layui.layer;
    var layDate = layui.laydate;
    var form = layui.form;
    var table = layui.table;
    var util = layui.util;
    var admin = layui.admin;
    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}
        ]];
    }
    // 数据渲染
    tableIns = table.render({
        elem: '#order',
        headers: {token: localStorage.getItem('token')},
        url: baseUrl+'/order/list/auth',
        page: true,
        limit: 15,
        limits: [15, 30, 50, 100, 200, 500],
        toolbar: '#toolbar',
        cellMinWidth: 50,
        height: 'full-120',
        cols: [[
            {type: 'checkbox'}
            ,{field: 'id', align: 'center',title: 'ID'}
            ,{field: 'uuid', align: 'center',title: '编号'}
            ,{field: 'orderNo', align: 'center',title: '订单编号'}
            ,{field: 'orderTime', align: 'center',title: '单据日期'}
            ,{field: 'docType$', align: 'center',title: '单据类型'}
            ,{field: 'itemId$', align: 'center',title: '项目编号'}
            ,{field: 'itemName', align: 'center',title: ''}
            ,{field: 'allotItemId$', align: 'center',title: '调拨项目编号'}
            ,{field: 'defNumber', align: 'center',title: '初始票据号'}
            ,{field: 'number', align: 'center',title: '票据号'}
            ,{field: 'cstmr$', align: 'center',title: '客户编号'}
            ,{field: 'cstmrName', align: 'center',title: '客户'}
            ,{field: 'tel', align: 'center',title: '联系方式'}
            ,{field: 'operMemb', align: 'center',title: '操作人员'}
            ,{field: 'totalFee', align: 'center',title: '合计金额'}
            ,{field: 'discount', align: 'center',title: '优惠率'}
            ,{field: 'discountFee', align: 'center',title: '优惠金额'}
            ,{field: 'otherFee', align: 'center',title: '销售或采购费用合计'}
            ,{field: 'actFee', align: 'center',title: '实付金额'}
            ,{field: 'payType$', align: 'center',title: '付款类型'}
            ,{field: 'salesman', align: 'center',title: '业务员'}
            ,{field: 'accountDay', align: 'center',title: '结算天数'}
            ,{field: 'postFeeType$', align: 'center',title: '邮费支付类型'}
            ,{field: 'postFee', align: 'center',title: '邮费'}
            ,{field: 'payTime$', align: 'center',title: '付款时间'}
            ,{field: 'sendTime$', align: 'center',title: '发货时间'}
            ,{field: 'shipName', align: 'center',title: '物流名称'}
            ,{field: 'shipCode', align: 'center',title: '物流单号'}
            ,{field: 'settle$', align: 'center',title: '订单状态'}
            ,{field: 'status$', align: 'center',title: '状态'}
            ,{field: 'createBy$', align: 'center',title: '添加人员'}
            ,{field: 'createTime$', align: 'center',title: '添加时间'}
            ,{field: 'updateBy$', align: 'center',title: '修改人员'}
            ,{field: 'updateTime$', align: 'center',title: '修改时间'}
            ,{field: 'memo', align: 'center',title: '备注'}
    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')}
        ]];
    }
            ,{fixed: 'right', title:'操作', align: 'center', toolbar: '#operate', width:120}
        ]],
        request: {
            pageName: 'curr',
            pageSize: 'limit'
    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')},
        data: {
            limit: 9999
        },
        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) {
            if (res.code === 403) {
        method: 'POST',
        success: function (res) {
            if (res.code === 200){
                docTypeData = res.data;
                renderDocTypeSelect();
            } else if (res.code === 403){
                top.location.href = baseUrl+"/";
            } else {
                layer.msg(res.msg, {icon: 2})
            }
            pageCurr=curr;
            limit();
        }
    })
    // 渲染表格
    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'
                });
            }
            }
        });
    }
    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()
            });
        }
    });
    // 监听排序事件
    table.on('sort(order)', 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}
        });
    // 搜索
    form.on('submit(tbSearch)', function (data) {
        insTb.reload({where: data.field, page: {curr: 1}});
    });
    // 监听头工具栏事件
    table.on('toolbar(order)', function (obj) {
        var checkStatus = table.checkStatus(obj.config.id).data;
        switch(obj.event) {
            case 'addData':
                showEditModel();
                break;
            case 'deleteData':
               if (checkStatus.length === 0) {
                   layer.msg('请选择要删除的数据', {icon: 2});
                   return;
               }
               del(checkStatus.map(function (d) {
                   return d.id;
               }));
               break;
            case 'exportData':
                admin.confirm('确定导出Excel吗', {shadeClose: true}, function(){
                    var titles=[];
                    var fields=[];
                    obj.config.cols[0].map(function (col) {
                        if (col.type === 'normal' && col.hide === false && col.toolbar == null) {
                            titles.push(col.title);
                            fields.push(col.field);
                        }
    // 添加
    $("#orderAddBtn").click(function () {
        showEditModel();
    });
    $("#createInspectionBtn").click(function () {
        openInspectionDialog('');
    });
    // 工具条点击事件
    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, data.orderNo, 4);
        } 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: '820px',
                offset: [top + 'px', (left - 530 + $a.outerWidth()) + 'px'],
                shade: .01,
                shadeClose: true,
                fixed: false,
                content: '<table id="lookSSXMTable" lay-filter="lookSSXMTable"></table>',
                success: function (layero) {
                    insLookTb = table.render({
                        elem: '#lookSSXMTable',
                        headers: {token: localStorage.getItem('token')},
                        url: baseUrl+'/orderDetl/list/auth',
                        where: {
                            order_id: data.id
                        },
                        page: true,
                        cellMinWidth: 100,
                        cols: getLookCols(),
                        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 () {
                            I18n.updateLayuiPagination();
                            $(layero).find('.layui-table-view').css('margin', '0');
                        },
                        size: ''
                    });
                    var exportData = {};
                    $.each($('#search-box [name]').serializeArray(), function() {
                        exportData[this.name] = this.value;
                }
            });
        }
    });
    function openInspectionDialog(buyerCode) {
        admin.open({
            type: 1,
            title: I18n.t('create_inspection_order'),
            content: $('#inspectionDialog').html(),
            area: '1200px',
            end: function () {
                $(document).off('i18n:languageChanged.inspection');
            },
            success: function (layero, dIndex) {
                I18n.updatePage($(layero));
                $(layero).children('.layui-layer-content').css('overflow', 'visible');
                var $container = $(layero);
                function getMatchingLocationCols() {
                    return [[
                        {type: 'numbers'},
                        {field: 'locNo', title: (typeof I18n !== 'undefined' ? I18n.t('location_no') : 'Location No')},
                        {field: 'specs', title: (typeof I18n !== 'undefined' ? I18n.t('style') : 'Style')},
                        {field: 'color', title: (typeof I18n !== 'undefined' ? I18n.t('color') : 'Color')},
                        {field: 'anfme', title: (typeof I18n !== 'undefined' ? I18n.t('qty') : 'Qty')}
                    ]];
                }
                var inspectionTable = table.render({
                    elem: '#matchingLocationsTable',
                    data: [],
                    page: true,
                    cellMinWidth: 80,
                    cols: getMatchingLocationCols(),
                    text: {none: (typeof I18n !== 'undefined' ? I18n.t('no_data') : 'No Data')},
                    done: function () {
                        I18n.updateLayuiPagination();
                        $(layero).find('.layui-table-view').css('margin', '0');
                    },
                    size: ''
                });
                $(document).on('i18n:languageChanged.inspection', function () {
                    if (typeof I18n !== 'undefined') {
                        I18n.updatePage($container);
                    }
                    inspectionTable.reload({
                        cols: getMatchingLocationCols(),
                        text: {none: (typeof I18n !== 'undefined' ? I18n.t('no_data') : 'No Data')}
                    });
                    var param = {
                        'order': exportData,
                        'fields': fields
                    };
                });
                function updateSummary(records) {
                    if (!records || !records.length) {
                        $container.find('#poSummaryBuyerPo').text('');
                        $container.find('#poSummaryTotalStyles').text(0);
                        $container.find('#poSummaryTotalColors').text(0);
                        $container.find('#poSummaryTotalCartons').text(0);
                        $container.find('#poSummaryTotalQty').text(0);
                        return;
                    }
                    var buyerPo = records[0].sku || '';
                    var styleSet = {};
                    var colorSet = {};
                    var cartonSet = {};
                    var totalQty = 0;
                    for (var i = 0; i < records.length; i++) {
                        var r = records[i];
                        if (r.specs) styleSet[r.specs] = true;
                        if (r.color) colorSet[r.color] = true;
                        if (r.batch) cartonSet[r.batch] = true;
                        if (r.anfme) totalQty += Number(r.anfme) || 0;
                    }
                    $container.find('#poSummaryBuyerPo').text(buyerPo);
                    $container.find('#poSummaryTotalStyles').text(Object.keys(styleSet).length);
                    $container.find('#poSummaryTotalColors').text(Object.keys(colorSet).length);
                    $container.find('#poSummaryTotalCartons').text(Object.keys(cartonSet).length);
                    $container.find('#poSummaryTotalQty').text(totalQty);
                }
                var lastSearchRecords = [];
                form.on('submit(inspectionSearch)', function (data) {
                    var searchParam = data.field || {};
                    $.ajax({
                        url: baseUrl+"/order/export/auth",
                        url: baseUrl + "/order/inspection/matchingLocations/auth",
                        headers: {'token': localStorage.getItem('token')},
                        data: JSON.stringify(param),
                        dataType:'json',
                        contentType:'application/json;charset=UTF-8',
                        method: 'POST',
                        data: searchParam,
                        method: 'GET',
                        success: function (res) {
                            layer.closeAll();
                            if (res.code === 200) {
                                table.exportFile(titles,res.data,'xls');
                                var records = res.data && res.data.records ? res.data.records : (res.data || []);
                                lastSearchRecords = records;
                                inspectionTable.reload({data: records, page: {curr: 1}});
                                updateSummary(records);
                            } else if (res.code === 403) {
                                top.location.href = baseUrl+"/";
                            } else {
                                layer.msg(res.msg, {icon: 2})
                                layer.msg(typeof I18n !== 'undefined' ? I18n.t(res.msg) : res.msg, {icon: 2});
                            }
                        }
                    });
                    return false;
                });
                break;
        }
    });
    // 监听行工具事件
    table.on('tool(order)', function(obj){
        var data = obj.data;
        switch (obj.event) {
            case 'edit':
                showEditModel(data);
                break;
            case "del":
                del([data.id]);
                break;
        }
    });
    /* 弹窗 - 新增、修改 */
    function showEditModel(mData) {
        admin.open({
            type: 1,
            area: '600px',
            title: (mData ? '修改' : '添加') + '订单状态',
            content: $('#editDialog').html(),
            success: function (layero, dIndex) {
                layDateRender(mData);
                form.val('detail', mData);
                form.on('submit(editSubmit)', function (data) {
                    var loadIndex = layer.load(2);
                $container.find('#inspectionCreateBtn').click(function () {
                    var buyerCodeInput = ($container.find('input[name="buyerShortCode"]').val() || buyerCode || '').trim();
                    if (!buyerCodeInput) {
                        var msg = 'Buyer short code不能为空';
                        if (typeof I18n !== 'undefined') {
                            msg = I18n.t('buyer_short_code') + I18n.t('form_required');
                        }
                        layer.msg(msg, {icon: 2});
                        return;
                    }
                    if (!lastSearchRecords || lastSearchRecords.length === 0) {
                        layer.msg('请先检索出匹配库位数据', {icon: 2});
                        return;
                    }
                    var orderNo = generateInspectionOrderNo(buyerCodeInput);
                    layer.load(2);
                    $.ajax({
                        url: baseUrl+"/order/"+(mData?'update':'add')+"/auth",
                        url: baseUrl + "/order/inspection/create/auth",
                        headers: {'token': localStorage.getItem('token')},
                        data: data.field,
                        contentType: 'application/json;charset=UTF-8',
                        data: JSON.stringify({
                            orderNo: orderNo,
                            buyerShortCode: buyerCodeInput,
                            records: lastSearchRecords
                        }),
                        method: 'POST',
                        success: function (res) {
                            layer.close(loadIndex);
                            layer.closeAll('loading');
                            if (res.code === 200) {
                                layer.msg(typeof I18n !== 'undefined' ? I18n.t(res.msg) : res.msg, {icon: 1});
                                layer.close(dIndex);
                                insTb.reload({page: {curr: 1}});
                            } else {
                                layer.msg(typeof I18n !== 'undefined' ? I18n.t(res.msg) : res.msg, {icon: 2});
                            }
                        },
                        error: function() {
                            layer.closeAll('loading');
                            layer.msg(typeof I18n !== 'undefined' ? I18n.t('load_failed') : 'Load failed', {icon: 2});
                        }
                    });
                });
            }
        });
    }
    // 显示表单弹窗
    function showEditModel(expTpe) {
        admin.open({
            type: 1,
            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.val('editForm', expTpe);
                if (expTpe) {
                    $('#orderNo').attr("disabled", "disabled");
                }
                // 表单提交事件
                form.on('submit(orderEditSubmit)', function (data) {
                    // 组装数据
                    if (xxDataList.length <= 0) {
                        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(I18n.t('detail_modify_qty_invalid'), {icon: 2});
                            return false;
                        }
                        if (nList[xi].anfme < nList[xi].workQty){
                            layer.msg(I18n.t('qty_cannot_less_than_worked'), {icon: 2});
                            return false;
                        }
                    }
                    layer.load(2);
                    $.ajax({
                        url: baseUrl+"/order/form/" + (isExpAdd?"add":"modify") + "/auth",
                        headers: {'token': localStorage.getItem('token')},
                        data: JSON.stringify({
                            orderId: Number(data.field.id),
                            docType: Number(data.field.docType),
                            orderNo: data.field.orderNo,
                            orderDetlList: nList
                        }),
                        contentType:'application/json;charset=UTF-8',
                        method: 'POST',
                        success: function (res) {
                            layer.closeAll('loading');
                            if (res.code === 200){
                                layer.close(dIndex);
                                layer.msg(res.msg, {icon: 1});
                                tableReload();
                                $(".layui-laypage-btn")[0].click();
                                layer.msg(typeof I18n !== 'undefined' ? I18n.t(res.msg) : res.msg, {icon: 1});
                            } else if (res.code === 403){
                                top.location.href = baseUrl+"/";
                            }else {
@@ -200,33 +469,210 @@
                    })
                    return false;
                });
                $(layero).children('.layui-layer-content').css('overflow', 'visible');
                layui.form.render('select');
                // 明细表格
                var xxDataList = [];
                var tbOptions = {
                    elem: '#formSSXMTable',
                    headers: {token: localStorage.getItem('token')},
                    data: xxDataList,
                    page: true,
                    height: '350px;',
                    cellMinWidth: 100,
                    cols: getFormCols(),
                    done: function (res) {
                        $(layero).find('.layui-table-view').css('margin', '0');
                    },
                    size: ''
                };
                if (!isExpAdd) {
                    $.ajax({
                        url: baseUrl+"/order/detl/all/auth?orderId=" + expTpe.id,
                        headers: {'token': localStorage.getItem('token')},
                        method: 'GET',
                        async: false,
                        success: function (res) {
                            if (res.code === 200){
                                xxDataList = res.data;
                                tbOptions.data = xxDataList;
                            } else if (res.code === 403){
                                top.location.href = baseUrl+"/";
                            }else {
                                layer.msg(res.msg, {icon: 2})
                            }
                        }
                    })
                }
                var insTbSSXM = table.render(tbOptions);
                // 工具条点击事件
                table.on('tool(formSSXMTable)', function (obj) {
                    var data = obj.data;
                    var layEvent = obj.event;
                    if (layEvent === 'edit') {
                        showEditModel2(data);
                    } else if (layEvent === 'del') {
                        if(data.workQty > 0){
                            layer.msg(I18n.t('work_qty_exists_cannot_delete'), {icon: 2});
                            return;
                        }
                        layer.confirm(I18n.t('confirm_delete_data'), {
                            title: I18n.t('info'),
                            shade: .1,
                            skin: 'layui-layer-admin',
                            btn: [I18n.t('confirm'), I18n.t('cancel')]
                        }, function (i) {
                            layer.close(i);
                            for (var j = 0; j < xxDataList.length; j++) {
                                if (xxDataList[j].matnr === data.matnr && xxDataList[j].batch === data.batch) {
                                    xxDataList.splice(j, 1);
                                    break;
                                }
                            }
                            insTbSSXM.reload({data: xxDataList, page: {curr: 1}});
                        });
                    }
                });
                // 明细数据修改
                table.on('edit(formSSXMTable)', function (obj) {
                    let index = obj.tr.attr("data-index");
                    let data = xxDataList[index];
                    if (obj.field === 'anfme'){
                        let vle = Number(obj.value);
                        if (isNaN(vle)) {
                            layer.msg(I18n.t('please_enter_number'), {icon: 2});
                            return false;
                        } else {
                            if (vle <= 0) {
                                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(I18n.t('input_qty_cannot_less_than_working'), {icon: 2});
                                // data[obj.field] = 0;
                                // insTbSSXM.reload({data: xxDataList});
                                return false;
                            }
                        }
                    }
                    data[obj.field] = obj.value;
                    insTbSSXM.reload({data: xxDataList});
                });
                $('#matAddBtnComment').click(function () {
                    showEditModel2();
                });
                // 显示添加明细表单弹窗
                function showEditModel2(exp) {
                    admin.open({
                        type: 1,
                        offset: '150px',
                        area: '680px',
                        title: (exp ? I18n.t('modify_detail') : I18n.t('add_detail')),
                        content: $('#matEditDialog').html(),
                        success: function (layero, dIndex) {
                            // 回显数据
                            form.val('matEditForm', exp);
                            // 表单提交事件
                            form.on('submit(matEditSubmit)', function (data) {
                                let selectList = matXmSelect.getValue();
                                for (let i = 0; i<selectList.length; i++) {
                                    let item = selectList[i];
                                    // 查询物料详情
                                    $.ajax({
                                        url: baseUrl+"/mat/covert/"+item.value+"/auth",
                                        headers: {'token': localStorage.getItem('token')},
                                        method: 'GET',
                                        async: false,
                                        success: function (res) {
                                            if (res.code === 200){
                                                xxDataList.push(res.data);
                                                insTbSSXM.reload({data: xxDataList, page: {curr: 1}});
                                            } else if (res.code === 403){
                                                top.location.href = baseUrl+"/";
                                            }else {
                                                layer.msg(res.msg, {icon: 2})
                                            }
                                        }
                                    })
                                }
                                layer.close(dIndex);
                                return false;
                            });
                            // 渲染物料选择
                            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',
                                },
                                collapse: true,
                                toolbar: { show: true },
                                filterable: true,
                                remoteSearch: true,
                                remoteMethod: function(val, cb, show){
                                    $.ajax({
                                        url: baseUrl+"/mat/all/get/kv",
                                        headers: {'token': localStorage.getItem('token')},
                                        data: {
                                            condition: val
                                        },
                                        method: 'POST',
                                        success: function (res) {
                                            if (res.code === 200){
                                                cb(res.data)
                                            } else {
                                                cb([]);
                                                layer.msg(res.msg, {icon: 2});
                                            }
                                        }
                                    });
                                }
                            })
                            // 弹窗不出现滚动条
                            I18n.updatePage($(layero));
                            $(layero).children('.layui-layer-content').css('overflow', 'visible');
                            layui.form.render('select');
                        }
                    });
                }
            }
        });
    }
    /* 删除 */
    function del(ids) {
        layer.confirm('确定要删除选中数据吗?', {
    // 删除单据
    function doDel(orderId) {
        layer.confirm(I18n.t('confirm_delete'), {
            title: I18n.t('info'),
            shade: .1,
            skin: 'layui-layer-admin',
            shade: .1
            btn: [I18n.t('confirm'), I18n.t('cancel')]
        }, function (i) {
            layer.close(i);
            var loadIndex = layer.load(2);
            layer.load(2);
            $.ajax({
                url: baseUrl+"/order/delete/auth",
                headers: {'token': localStorage.getItem('token')},
                data: {ids: ids},
                data: {
                    orderId: orderId
                },
                method: 'POST',
                success: function (res) {
                    layer.close(loadIndex);
                    layer.closeAll('loading');
                    if (res.code === 200){
                        layer.msg(res.msg, {icon: 1});
                        tableReload();
                        if (insTbCount === 0) {
                            insTb.reload({page: {curr: 1}});
                        } else {
                            $(".layui-laypage-btn")[0].click();
                        }
                        layer.msg(typeof I18n !== 'undefined' ? I18n.t(res.msg) : res.msg, {icon: 1});
                    } else if (res.code === 403){
                        top.location.href = baseUrl+"/";
                    } else {
                    }else {
                        layer.msg(res.msg, {icon: 2});
                    }
                }
@@ -234,61 +680,111 @@
        });
    }
    // 搜索
    form.on('submit(search)', function (data) {
        pageCurr = 1;
        tableReload(false);
    });
    // 重置
    form.on('submit(reset)', function (data) {
        pageCurr = 1;
        clearFormVal($('#search-box'));
        tableReload(false);
    });
    // 时间选择器
    function layDateRender(data) {
        setTimeout(function () {
            layDate.render({
                elem: '#payTime\\$',
                type: 'datetime',
                value: data!==undefined?data['payTime\\$']:null
            });
            layDate.render({
                elem: '#sendTime\\$',
                type: 'datetime',
                value: data!==undefined?data['sendTime\\$']:null
            });
            layDate.render({
                elem: '#createTime\\$',
                type: 'datetime',
                value: data!==undefined?data['createTime\\$']:null
            });
            layDate.render({
                elem: '#updateTime\\$',
                type: 'datetime',
                value: data!==undefined?data['updateTime\\$']:null
            });
        }, 300);
    // 修改订单状态
    function doModify(orderId, orderNo, settle) {
        layer.confirm(I18n.t('confirm_manual_complete'), {
            shade: .1,
            skin: 'layui-layer-admin'
        }, function (i) {
            layer.close(i);
            layer.load(2);
            console.log(orderId);
            console.log(settle);
            $.ajax({
                url: baseUrl+"/order/update/auth",
                headers: {'token': localStorage.getItem('token')},
                data: {
                    id: orderId,
                    orderNo: orderNo,
                    settle: settle
                },
                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(typeof I18n !== 'undefined' ? I18n.t(res.msg) : res.msg, {icon: 1});
                    } else if (res.code === 403){
                        top.location.href = baseUrl+"/";
                    }else {
                        layer.msg(res.msg, {icon: 2});
                    }
                }
            })
        });
    }
    layDateRender();
});
    // 任务追溯
    function showWrkTrace(orderId) {
        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')},
            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: I18n.t('wrk_trace'),
                            area: ['800px', '450px'],
                            shadeClose: true,
                            content: html,
                            success: function (layero, dIndex) {
                            I18n.updatePage($(layero));
                            $(layero).children('.layui-layer-content').css('overflow', 'visible');
                            /** 统计图表 */
                                var traceCharts = echarts.init(document.getElementById('wrkTraceCharts'));
                                var traceOptions = {
                                    title: {
                                        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: I18n.t('quantity'), type: 'pie', radius: ['75%', '80%'], label: {normal: {show: false}}}]
                                };
                                traceCharts.setOption(traceOptions);
                                // 赋值
                                traceCharts.setOption({
                                    title: {
                                        subtext: res.data.totalQty+"/"+res.data.wrkQty+"/"+res.data.endQty
                                    },
                                    series: [
                                        {
                                            data: [
                                                {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},
                                            ]
                                        }
                                    ]
                                });
                            }
                        });
                    });
                } else if (res.code === 403){
                    top.location.href = baseUrl+"/";
                }else {
                    layer.msg(res.msg, {icon: 2});
                }
            }
        })
    }
// 关闭动作
$(document).on('click','#data-detail-close', function () {
    parent.layer.closeAll();
});
function tableReload(child) {
    var searchData = {};
    $.each($('#search-box [name]').serializeArray(), function() {
        searchData[this.name] = this.value;
    layDate.render({
        elem: '.layui-laydate-range'
        ,type: 'datetime'
        ,range: true
    });
    tableIns.reload({
        where: searchData,
        page: {curr: pageCurr}
     });
}
});