baselocation.js 8.35 KB
let action = null;
layui.config({
    base: "/js/",
    version: 23
}).use(['system'], function () {
    var form = layui.form,
        $ = layui.jquery,
        element = layui.element,
        table = layui.table,
        system = layui.system,
        sysU = new system.u(),
        sendData = null,
        areaName = "Distribution",
        controllerName = "BaseLocation",
        app = null;

        action = {
        addOptions: function () {
            var options = {
                fromId: "#modifyForm form",
                url: `/${areaName}/${controllerName}/Ins`,
                submit: "submit(fromAdd)"
            }
            return options;
        },

        editOptions: function () {
            debugger;
            $("#locationCode").css("background-color", "#F5F5F5");
            $("#locationCode").attr("disabled", "disabled");
            $("#locationName").css("background-color", "#F5F5F5");
            $("#locationName").attr("disabled", "disabled");
            var options = {
                fromId: "#modifyForm form",
                url: `/${areaName}/${controllerName}/Upd`,
                submit: "submit(fromUpdate)"
            }
            return options;  
        },

        deleteOptions: function () {
            var options = {
                url: `/${areaName}/${controllerName}/DelByIds`,
                keyId: "id"
            }
            return options;
        },

        exportOptions: function () {
            var options = {
                fromId: "listForm",
                url: `/${areaName}/${controllerName}/Export`,
                isDefault: false,
                excelCols: {
                    head: app.data.cols,
                    body: app.data.colsDesc
                }
            }
            return options;
        },

        queryOptions: function () {
            var options = {
                resetFrom: "form[lay-filter=listForm]",
                fromId: "listForm",
                urlExport: `/${areaName}/${controllerName}/Export`,
                urlQuery: `/${areaName}/${controllerName}/Load`,
                mainTable: app.data.tableIns
            }
            return options;
        },

        uploadOptions: function () {
            var options = {
                url: `/${areaName}/${controllerName}/Import`,
                fromFile: "#excelfile",
                content: $("#ImportData")
            }
            return options;
        },

        editBefore: function (data, callBack) {
            
            form.val("modifyForm", data);
            if (callBack != null) callBack();
        },

        //来源料点配置
        btnStepStation: function (data, toolbarId) {
            let checkStatus = table.checkStatus(toolbarId);
            if (checkStatus.data.length != 1) {
                layer.msg(sysU.config.titleSelectOne, { icon: sysU.config.iconoError, shade: 0.4, time: sysU.config.msgOpenTime });
                return;
            }

            var locationCode = checkStatus.data[0].locationCode;
            var locationName = checkStatus.data[0].locationName;
            var zoneCode = checkStatus.data[0].zoneCode;

            if (zoneCode == 10) {
                layer.msg("装料点不能配置来源料点", { icon: sysU.config.iconoError, shade: 0.4, time: sysU.config.msgOpenTimeLong });
                return;
            }

            var url = `/distribution/BaseLocation/LocationChoice?menuFlag=-2&selectColKeyCustom=locationCode&timestamp=${new Date().getTime()}&page=LocationChoice&locationCode=${locationCode}`;
            var index = layer.open({
                title: "为料点【" + locationName + "】配置来源料点",
                type: 2,
                area: ['1000px', '600px'],
                content: url,
                cancel: function () {
                    $('a[lay-event="btnRefresh"]').click();
                }
            });
            localStorage.setItem("openIndex", index);
        },

        //初始化字典
        btnIniLocation: function () {

            app.methods.setData();
        },

        //所有动作成功之后
        actionSuccess: (falg) => {
            app.data.tableIns.config.where = {};
            app.data.tableIns.config.page.curr = 1;
            app.data.tableIns.reload(app.data.tableElem, {});
        }
    }

    app = {
        data: {
            cols: [[
                { type: "radio", fixed: true },
                { field: "id", width: 80, hide: true, title: "Id" },
                { field: "keys", width: 80, hide: true, title: "Keys" },
                { field: "locationCode", width: 180, title: "料点编码" },
                { field: "locationName", width: 150, title: "料点名称" },
                { field: "stationCode", width: 150, title: "工位编码" },
                { field: "peopleStation", width: 120, title: "来源料点" },
                { field: "locationStatus", width: 120, title: "料点状态", templet: function (obj) {
                        return "".GetState(window.top.EnumLocationStatus, obj.locationStatus);
                    }
                },
                { field: "lineCode", width: 150, hide: true, title: "线体" },
                { field: "fitupArea", width: 150, hide: true, title: "组队上料区域号" },
                { field: "locationType", width: 100, title: "库位类型" },
                { field: "containerCode", width: 100, title: "容器编码" },
                {
                    field: "zoneCode", width: 100, title: "区域编码", templet: function (obj) {
                        return "".GetState(window.top.EnumLocationZoneCode, obj.zoneCode);
                    }
                },
                { field: "warehouseCode", width: 150, hide: true, title: "仓库编码" },
                { field: "sensorPropCode", width: 150, hide: true, title: "是否有料框" },
                { field: "isLightFence", width: 150, hide: true, title: "是否有光栅", templet: '#isDeleteTpl' },
                {
                    field: "callType", width: 100, title: "料点类型", templet: function (obj) {
                        return "".GetState(window.top.EnumCallType, obj.callType);
                    }
                },
                { field: "feedGroupCode", width: 100, hide: true, title: "叫料分组编码" },
                { field: "loadGroupCode", width: 100, hide: true, title: "装料分组编码" },
                { field: "createTime", width: 150, hide: true, title: "创建时间" }
            ]],
            tableIns: null,
            tableElem: "mainList",
            //下拉框配置
            selectOption: {
                //station: {
                //    SelType: "FromUrl",
                //    SelFrom: `/${areaName}/${controllerName}/StationLineSelect`,
                //    SelLabel: "workStationName",
                //    SelValue: "workStationCode",
                //    OptGroup: true,
                //    Dom: [$("[name='stationCode']")]
                //},
                //返回的数据 用于后续操作
                selectData: {

                }
            }
        },
        methods: {
            initTable: function () {
                let options = {
                    elem: "#" + app.data.tableElem,
                    url: `/${areaName}/${controllerName}/Load`,
                    cols: sysU.columnRecord(app.data.tableElem, app.data.cols),
                    toolbar: '#toolbarTable',
                }
                app.data.tableIns = sysU.initTable(options);
            },

            initSelectTable: function () {

            },//初始化字典数据
            setData: function () {
                var ajaxConfig = {
                    loading: true,
                    type: "post",
                    url: `/${areaName}/${controllerName}/IniLocationVm`,
                    success: function (result) {
                        if (sysU.successBefore(result)) return;
                        console.log(result);
                        layer.msg("操作成功!");
                    }
                };
                sysU.ajax(ajaxConfig);
            },
            initFrom() {
                sysU.initSelect(app.data.selectOption);
            }
        },
        registerEvent: function () {

        },
        init: function () {
            app.methods.initTable();
            app.methods.initFrom();
            app.registerEvent();
        }
    };
    app.init();
});