#
luxiaotao1123
2020-06-17 58af6a752a2d06920fd2b456662569c02f96a071
src/main/webapp/static/js/pakStore/pakStore.js
@@ -1,3 +1,7 @@
var initCountVal = 0;
var matCodeData = [];
layui.use(['table','laydate', 'form'], function() {
    var table = layui.table;
    var $ = layui.jquery;
@@ -5,34 +9,170 @@
    var layDate = layui.laydate;
    var form = layui.form;
    // 获取可用入库站点
    $.ajax({
        url: baseUrl+"/available/put/site",
        headers: {'token': localStorage.getItem('token')},
        method: 'POST',
        success: function (res) {
            if (res.code === 200){
                var tpl = $("#putSiteSelectTemplate").html();
                var template = Handlebars.compile(tpl);
                var html = template(res);
                $('#putSiteSelect').append(html);
                form.render('select');
            } else if (res.code === 403){
                top.location.href = baseUrl+"/";
            }else {
                layer.msg(res.msg)
            }
        }
    })
    tableIns = table.render({
        elem: '#chooseData',
        data: [],
        even: true,
        limit: 500,
        cellMinWidth: 50,
        toolbar: '#toolbar',
        cols: [[
            {type: 'checkbox'},
            {field: 'matNo', align: 'center', title: '物料编码', sort: 'true'},
            {fixed: 'left', field: 'count', title: '数量(必填)', align: 'center', edit:'text', width: 120,  style:'color: blue;font-weight: bold'},
            {field: 'matNo', align: 'center', title: '物料编码'},
            {field: 'barcode', align: 'center', title: '条码'},
            {field: 'matName', align: 'center', title: '物料名称'},
            {field: 'str1', align: 'center', title: '物料单位'},
            {field: 'str2', align: 'center', title: '物料规格'},
            {field: 'count', title: '数量', align: 'center', edit:'text', width: 100}
            {fixed: 'right', title:'操作', align: 'center', toolbar: '#operate', width:80}
        ]],
        done: function (res, curr, count) {
            $('td[data-field=count] div').html(initCountVal);
            setMatCodeData(res.data);
            limit();
        }
    });
    // 页面修改
    table.on('edit(chooseData)', function (obj) {
        if (!isNaN(obj.value)) {
            updateMatCodeData(obj.data.matNo, Number(obj.value));
        } else {
            layer.msg("请输入数字");
        }
    });
    // 监听头工具栏事件
    table.on('toolbar(chooseData)', function (obj) {
        var checkStatus = table.checkStatus(obj.config.id);
        var data = checkStatus.data;
        switch(obj.event) {
            case 'comb':
                // 判断是否存在物料
                if (matCodeData.length === 0) {
                    layer.msg("请先添加物料");
                    return;
                }
                // 判断物料数量是否存在异常
                for (var i=0;i<matCodeData.length;i++){
                    if (isNaN(matCodeData[i].count)) {
                        layer.msg("请输入数字");
                        return;
                    }
                    if (matCodeData[i].count === 0){
                        layer.msg("数量不能为零");
                        return;
                    }
                }
                layer.open({
                    type: 1,
                    title: '选择入库站',
                    maxmin: true,
                    shadeClose: true,
                    content: $('#combDiv'),
                    success: function (layero, index) {
                    }
                })
                break;
        }
    });
    // 监听行工具事件
    table.on('tool(chooseData)', function(obj){
        var data = obj.data;
        switch (obj.event) {
            // 详情
            case 'remove':
                for (var i = matCodeData.length - 1; i >= 0; i--) {
                    if (matCodeData[i].matNo === data.matNo) {
                        matCodeData.splice(i, 1);
                    }
                }
                tableIns.reload({data: matCodeData,done:function (res) {
                        limit();
                        // 覆盖render方法的done
                    }});
                break;
        }
    });
    function setMatCodeData(data) {
        matCodeData = data;
        for (var i=0;i<matCodeData.length;i++){
            matCodeData[i]["count"] = initCountVal;
        }
    }
    function updateMatCodeData(matNo, count) {
        if (count > 0) {
            for (var i=0;i<matCodeData.length;i++){
                if (matCodeData[i]["matNo"] === matNo){
                    matCodeData[i]["count"] = count;
                }
            }
        } else {
            layer.msg("数量必须大于零");
        }
        tableIns.reload({data: matCodeData,done:function (res) {
                limit();
                // 覆盖render方法的done
            }});
    }
    // 表单 --- 启动入库
    form.on('submit(combDo)', function (data) {
        $.ajax({
            url: baseUrl+"/full/store/put/start",
            headers: {'token': localStorage.getItem('token')},
            data: JSON.stringify({
                devpNo: $('#putSiteSelect').val(),
                list: matCodeData
            }),
            contentType:'application/json;charset=UTF-8',
            method: 'POST',
            async: false,
            success: function (res) {
                if (res.code === 200){
                    layer.closeAll();
                    layer.msg("入库启动成功,目标库位:" + res.data);
                    matCodeData = [];
                    tableIns.reload({data: matCodeData,done:function (res) { limit();}});
                } else if (res.code === 403){
                    top.location.href = baseUrl+"/";
                }else {
                    layer.msg(res.msg)
                }
            }
        })
    });
});
// 提取物料
var matCodeLayerIdx;
function getMat() {
    tableIns.reload({data: []})
    matCodeLayerIdx = layer.open({
        type: 2,
        title: '库位物料',
        title: '提取物料',
        maxmin: true,
        area: [top.detailWidth, top.detailHeight],
        shadeClose: true,
@@ -40,4 +180,4 @@
        success: function(layero, index){
        }
    });
}
}