Location.js 6.93 KB
let action = null;

layui.config({
    base: "/js/",
    version: 111
}).use(["system"], function () {
    var form = layui.form,
        $ = layui.jquery,
        system = layui.system,
        u = new system.u(),
        areaName = "warehous",
        tableName = "Location";

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

        editOptions: function () {
            var options = {
                fromId: "#modifyForm form",
                url: `/${areaName}/${tableName}/Upd`,
                submit: "submit(fromUpdate)"
            }
            return options;
        },

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

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

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

        uploadOptions: function () {
            var options = {
                url: `/${areaName}/${tableName}/Import`,
                fromFile: "#excelfile",
                content: $("#ImportData")
            }
            return options;
        },
        addBefore: function (callBack) {
            //callBack是回调函数,如果editBefore有ajax 放在成功之后
            if (callBack != null) callBack();
        },
        editBefore: function (data, callBack) {
            debugger
            form.val("modifyForm", data);
            if (callBack != null) callBack();
        },

        editAfter: function (callBack) {

            if (callBack != null) callBack();
        },

        addSaveBefore: function (data, callBack) {
            if (callBack != null) callBack();
        },


        //所有动作成功之后
        actionSuccess: (falg) => {
            u.refreshTable(app, u, null, falg);
        }
    }

    var app = {
        data: {
            cols: [[
                { checkbox: true, fixed: true },
                { field: "id", width: 80,  title: "Id" },
                { field: "locationCode", width: 150, title: "库位编码" },
                { field: "locationName", width: 150, title: "库位名称" },
                { field: "lineCode", width: 150,  title: "线体编码" },
                {
                    field: "lineName", width: 150, title: "线体名称", templet: function (d) {
                        return GetLabel("lineCode", "LineCode", "LineName", d.lineCode);
                } },

                { field: "locationType", width: 150,  title: "库位类型", templet: function (d) { return GetLabel("type", "DictValue", "DictLabel", d.locationType) } },
                { field: "containerId", width: 150,  hide: true, title: "容器id号" },
                { field: "containerCode", width: 150,  hide: true, title: "容器编码" },
                { field: "zoneCode", width: 150,  title: "区域编码", templet: function (d) { return GetLabel("zoneCode", "DictValue", "DictLabel", d.zoneCode) } },
                {
                    field: "locationStatus", width: 130,  title: "状态", templet: function (d) {
                        return GetLabel("locationStatus", "DictValue", "DictLabel", d.locationStatus);
                } },


                { field: "createTime", width: 150,  title: "创建时间" },
                { field: "createBy", width: 100,  title: "创建用户" },
                { field: "cpdateTime", width: 150,  title: "更新时间" },
                { field: "cpdateBy", width: 100,  title: "更新用户" }
            ]],
            tableIns: null,
            tableElem: "mainList",

            selectOption: {
                locationStatus: {
                    SelType: "FromDict",
                    SelFrom: "locationStatus",
                    SelLabel: "DictLabel",
                    SelValue: "DictValue",
                    Dom: [$("[name='locationStatus']")]
                },
                locationType: {
                    SelType: "FromDict",
                    SelFrom: "materialPointType",
                    SelLabel: "DictLabel",
                    SelValue: "DictValue",
                    Dom: [$("[name='locationType']")]
                },
                zoneCode: {
                    SelType: "FromDict",
                    SelFrom: "zoneCode",
                    SelLabel: "DictLabel",
                    SelValue: "DictValue",
                    Dom: [$("[name='zoneCode']")]
                },
                lineCode: {
                    SelType: "FromUrl",
                    SelFrom: "/HomeRedis/GetBaseInfoByKey?key=base_line",
                    SelLabel: "LineName",
                    SelValue: "LineCode",
                    Dom: [$("[name='lineCode']")]
                },
                Warehouse: {
                    SelType: "FromUrl",
                    SelFrom: "/HomeRedis/GetBaseInfoByKey?key=base_warehouse",
                    SelLabel: "name",
                    SelValue: "code",
                    Dom: [$("[name='warehouseCode']")]
                },
                stationCode: {
                    SelType: "FromUrl",
                    SelFrom: "/configure/Station/Load?keyword=FitUp",
                    SelLabel: "workStationName",
                    SelValue: "workStationCode",
                    Dom: [$("[name='stationCode']")]
                },
                //返回的数据 用于后续操作
                selectData: {

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


        registerEvent: function () {

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