自动化立体仓库 - WMS系统
#
luxiaotao1123
2022-10-17 983c8fc9697223956db395af1b781ddb75c6e0b5
src/main/webapp/static/js/order/out.js
@@ -4,7 +4,7 @@
    base: baseUrl + "/static/layui/lay/modules/"
}).extend({
    notice: 'notice/notice',
}).use(['table','laydate', 'form', 'util', 'admin', 'notice', 'treeTable', 'xmSelect', 'tableMerge'], function(){
}).use(['table','laydate', 'form', 'util', 'admin', 'notice', 'treeTable', 'xmSelect', 'tableMerge', 'tableX'], function(){
    var table = layui.table;
    var $ = layui.jquery;
    var layer = layui.layer;
@@ -16,6 +16,7 @@
    var treeTable = layui.treeTable;
    var xmSelect = layui.xmSelect;
    var tableMerge = layui.tableMerge;
    var tableX = layui.tableX;
    insTb2 = table.render({
        elem: '#orderDetlTable',
@@ -26,6 +27,7 @@
        limits: [15, 30, 50, 100, 200, 500],
        toolbar: '#orderDetToolbar',
        height: 'full-120',
        where: {order_id: 9999999999},
        cols: [[
            {type: 'checkbox'}
            ,{type: 'numbers', title: '#'}
@@ -77,6 +79,7 @@
            limit();
        }
    });
    /* 表格2搜索 */
    form.on('submit(sensorTbSearch)', function (data) {
        insTb2.reload({where: data.field, page: {curr: 1}});
@@ -85,6 +88,7 @@
    /* 表格2头工具栏点击事件 */
    table.on('toolbar(orderDetlTable)', function (obj) {
        var checkStatus = table.checkStatus(obj.config.id).data;
        if (obj.event === 'pakoutPreview') { // 添加
            if (checkStatus.length === 0) {
@@ -158,7 +162,7 @@
                                    {field: 'anfme', title: '数量', align: 'center', width: 90, style: 'font-weight: bold'},
                                    {field: 'locNo', title: '货位', align: 'center', width: 100, templet: '#locNoTpl'},
                                    {field: 'staNos', align: 'center', title: '出库站', merge: ['locNo'], templet: '#tbBasicTbStaNos'},
                                    {type: 'checkbox', merge: ['locNo']},
                                    // {type: 'checkbox', merge: ['locNo']},
                                ]],
                                done: function (res) {
                                    tableMerge.render(this);
@@ -175,33 +179,34 @@
                                        tableCache[i]['staNo'] = Number(obj.elem.value);
                                    }
                                }
                                // data['staNo'] = Number(obj.elem.value);
                                obj.othis.children().find("input").css("color", "blue");
                                return false;
                            });
                            // 批量修改出库站
                            form.on('submit(batchModifySta)', function () {
                                let stoPreTabData = layui.table.checkStatus('stoPreTab').data;
                                if (stoPreTabData.length < 1) {
                                    layer.msg("请至少选择一条以上合并数据", {icon: 7});
                                    return false;
                                }
                                modifySta(stoPreTabData);
                                modifySta();
                            });
                            // 批量修改出库站 - 站点选择
                            function modifySta(stoPreTabData) {
                            function modifySta() {
                                // 出库站取交集
                                let staBatchSelectVal = [];
                                for(let i = 0; i<stoPreTabData.length; i++) {
                                    if (i === 0) {
                                        staBatchSelectVal = stoPreTabData[i].staNos;
                                    } else {
                                        let staNos = stoPreTabData[i].staNos;
                                        staBatchSelectVal = staBatchSelectVal.filter( val => {
                                                return new Set(staNos).has(val)
                                            }
                                        )
                                for(let i = 0; i<tableCache.length; i++) {
                                    let staNos = tableCache[i].staNos;
                                    if (staNos !== null) {
                                        if (staBatchSelectVal.length === 0) {
                                            staBatchSelectVal = staNos;
                                        } else {
                                            staBatchSelectVal = staBatchSelectVal.filter(val =>
                                                {
                                                    return new Set(staNos).has(val)
                                                }
                                            )
                                        }
                                    }
                                }
                                if (staBatchSelectVal.length === 0) {
                                    layer.msg("出库站没有交集,无法批量修改", {icon: 2});
                                    return;
                                }
                                admin.open({
                                    type: 1,
@@ -218,21 +223,18 @@
                                            let loadIdx = layer.load(2);
                                            let batchSta = Number(obj.field.batchSta);
                                            let arr = [];
                                            for (let j = 0; j<stoPreTabData.length; j++) {
                                                for (let i = 0; i<tableCache.length; i++) {
                                                    if (tableCache[i].orderNo === stoPreTabData[j].orderNo
                                                        && tableCache[i].matnr === stoPreTabData[j].matnr
                                                        && tableCache[i].locNo === stoPreTabData[j].locNo) {
                                                        tableCache[i]['staNo'] = batchSta;
                                                        arr.push(i);
                                                    }
                                                }
                                            for (let i = 0; i<tableCache.length; i++) {
                                                tableCache[i]['staNo'] = batchSta;
                                                arr.push(i);
                                            }
                                            stoPreTabIdx.reload({data: tableCache})
                                            stoPreTabIdx.reload({data: tableCache});
                                            arr.forEach(item => {
                                                $('div[lay-id=stoPreTab] tr[data-index="' + item + '"] .order-sta-select').val(batchSta);
                                            })
                                            });
                                            layui.form.render('select');
                                            arr.forEach(item => {
                                                $('div[lay-id=stoPreTab] tr[data-index="' + item + '"] .layui-select-title').find("input").css("color", "blue");
                                            });
                                            layer.close(loadIdx); layer.close(ddIndex);
                                            return false;
                                        });
@@ -329,6 +331,148 @@
        })
    })
    window.pakoutPreview = pakoutPreview;
    // 合并出库
    form.on('submit(mergeOut)', function (data) {
        let checkStatus = layui.table.checkStatus('originTable').data;
        if (checkStatus.length < 2) {
            layer.msg("请至少选择两条以上合并数据", {icon: 7});
            return false;
        }
        showMerge(checkStatus.map(function (d) {
            return d.id;
        }));
    });
    // 订单合并窗口
    function showMerge(orderIds) {
        let loadIndex = layer.load(2);
        $.ajax({
            url: baseUrl+"/order/merge/preview/auth",
            headers: {'token': localStorage.getItem('token')},
            method: 'GET',
            data: {
                orderIds: orderIds
            },
            success: function (res) {
                layer.close(loadIndex);
                if (res.code === 200){
                    admin.open({
                        type: 1,
                        title: '订单合并 【 数量:' + orderIds.length + " 】",
                        content: $('#mergeDialog').html(),
                        area: '900px',
                        success: function (layero, dIndex) {
                            $('#newOrderNo').val(res.data.newOrderNo);
                            // 渲染客户列表
                            let cstmrVal = xmSelect.render({
                                el: '#cstmrSelect',
                                radio: true,
                                clickClose: true,
                                filterable: true,
                                create: function(val, arr){
                                    if(arr.length === 0){
                                        return {
                                            name:  val,
                                            value: val
                                        }
                                    }
                                },
                                model: {
                                    icon: 'hidden',
                                    label: {
                                        type: 'text',
                                    }
                                },
                                data: res.data.cstmrs
                            })
                            // 渲染明细
                            let xxDataList = res.data.orderDetls;
                            let tbOptions = {
                                elem: '#mergeTable',
                                headers: {token: localStorage.getItem('token')},
                                data: xxDataList,
                                limit: 9999,
                                height: '350px;',
                                cellMinWidth: 100,
                                cols: [[
                                    {type: 'numbers', title: '#'},
                                    {field: 'matnr', title: '商品编码', minWidth: 170},
                                    {field: 'maktx', title: '商品名称'},
                                    {field: 'batch', title: '批号'},
                                    {field: 'anfme', title: '数量', minWidth: 80, width: 80},
                                    {field: 'unitPrice', title: '单价(修改)', style: 'color: blue;font-weight: bold', edit: true, minWidth: 120, width: 120, fixed: 'right'},
                                    // {align: 'center', title: '操作', toolbar: '#formSSXMTableBar', minWidth: 80, width: 80}
                                ]],
                                done: function (res) {
                                    $(layero).find('.layui-table-view').css('margin', '0');
                                }
                            };
                            let insMergeTb = table.render(tbOptions);
                            // 价格修改
                            table.on('edit(mergeTable)', function (obj) {
                                let unitPrice = Number(obj.value);
                                if (isNaN(unitPrice)) {
                                    layer.msg("请输入数字", {icon: 2});
                                } else {
                                    if (unitPrice > 0) {
                                        for (let i=0;i<xxDataList.length;i++){
                                            if (xxDataList[i]["matnr"] === obj.data.matnr && xxDataList[i]["batch"] === obj.data.batch){
                                                xxDataList[i]["unitPrice"] = unitPrice;
                                                break;
                                            }
                                        }
                                    } else {
                                        layer.msg("数量必须大于零", {icon: 2});
                                    }
                                }
                                insMergeTb.reload({data: xxDataList});
                            });
                            // 合并表单提交事件
                            form.on('submit(mergeSubmit)', function (data) {
                                let nList = admin.util.deepClone(xxDataList);
                                data.field.cstmr = cstmrVal.getValue()[0] ? cstmrVal.getValue()[0].name : null;
                                layer.load(2);
                                $.ajax({
                                    url: baseUrl+"/delivery/merge/auth",
                                    headers: {'token': localStorage.getItem('token')},
                                    data: JSON.stringify({
                                        oldOrderIds: orderIds,
                                        orderNo: data.field.newOrderNo,
                                        cstmr: data.field.cstmr,
                                        orderDetls: nList
                                    }),
                                    contentType:'application/json;charset=UTF-8',
                                    method: 'POST',
                                    success: function (res) {
                                        layer.closeAll('loading');
                                        if (res.code === 200){
                                            layer.close(dIndex);
                                            $(".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});
                                        }
                                    }
                                })
                                return false;
                            });
                            $(layero).children('.layui-layer-content').css('overflow', 'visible');
                        }
                    });
                } else if (res.code === 403){
                    top.location.href = baseUrl+"/";
                } else {
                    layer.msg(res.msg, {icon: 2})
                }
            }
        })
    }
});
function tableReload(child) {
@@ -344,3 +488,25 @@
    });
}
/**
 * 一键出库
 */
function autoOut(orderId) {
    let loadIndex = layer.msg('请求中...', {icon: 16, shade: 0.01, time: false});
    $.ajax({
        url: baseUrl + "/out/pakout/orderDetlIds/auth",
        headers: {'token': localStorage.getItem('token')},
        data: { orderId : orderId },
        method: 'POST',
        success: function (res) {
            layer.close(loadIndex);
            if (res.code === 200){
                pakoutPreview(res.data);
            } else if (res.code === 403){
                top.location.href = baseUrl+"/";
            } else {
                layer.msg(res.msg, {icon: 2});
            }
        }
    })
}