ProductionOrder.js 6.74 KB
var action = null;

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

    action = {
        rowData: null,

        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: "id"
            }
            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;
        },

        editBefore: function (data, callBack) {
            form.val("modifyForm", data);
            //callBack是回调函数,如果editBefore有ajax 放在成功之后
            if (callBack != null) callBack();
        },

        editSaveBefore: function (data, callBack) {
            if (data.field.lineCode1 == "" && data.field.lineCode2 == "") {
                layer.alert("你必须选择最少一个线体", { icon: 2, shadeClose: true, title: u.config.titleEdit });
                return false;
            }
            if (callBack != null) callBack();
        },

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

        selectProduct: function () {
            var height = 600;
            u.openPage({
                area: ["1100px", height + "px"],
                title: "选择产品",
                btn: ['选择', '关闭'],
                checkTableRowDataCount: 1,
                type: 2,
                yesCallBackFn: function (data, callBack) {
                    console.log("endCallBackFn", data);
                    action.actionSuccess(app.data.tableElemDesc);
                },
                content: `/configure/ProductHeader/Index?type=selectProduct`,
            }, action)
        },

        btnComplete: function (sysU, toolbarId) {
            var checkStatus = {};
            if (!table.checkStatus) {
                checkStatus["data"] = [action.rowData];
            } else {
                checkStatus = table.checkStatus(toolbarId);
            }
            var selectRow = checkStatus.data.length;//选中的行数
            if (selectRow === 0 || selectRow > 1) {
                layer.alert("请选择一条数据", { icon: sysU.config.iconoError, shadeClose: true, title: "错误信息" });
                return false;
            }
        },

        //所有动作成功之后
        actionSuccess: (falg) => {
            if (falg === "add" || falg === "edit" || falg === "delete" || falg === "refresh" || falg === "upload") {
                app.data.tableIns.config.where = {};
                app.data.tableIns.config.page.curr = 1;
                app.data.tableIns.reload("mainList", {});
            }
        }
    }

    var app = {
        data: {
            cols: [[
                { checkbox: true, fixed: true },
                { field: "id", width: 80,  hide: true, title: "Id" },
                { field: "keys", width: 80, hide: true, title: "keys" },
                { field: "planCode", width: 120, title: "工单编号" },
                { field: "planName", width: 150, title: "工单名称" },
                { field: "productCode", width: 150, title: "产品编码" },
                { field: "productName", width: 150, title: "产品名称" },
                { field: "processRouteKeys", width: 150, hide: true, title: "工艺路线keys" },
                { field: "processName", width: 150, title: "工艺路线名称" },
                { field: "quantity", width: 100, title: "生产数量" },
                { field: "batchCode", width: 100, title: "批次号" },
                { field: "requestDate", width: 100, title: "需求日期" },
                { field: "parentKeys", width: 100, hide: true, title: "父节点keys" },
                { field: "lineCode", width: 100, title: "线体编号" },
                { field: "status", width: 100, title: "单据状态" },
                { field: "remark", width: 100, title: "备注" },

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

            selectOption: {
                materialtype: {
                    SelType: "FromUrl",
                    SelFrom: "/HomeRedis/GetBaseInfoByKey?key=base_material_type",
                    SelLabel: "name",
                    SelValue: "code",
                    Dom: [$("select[name='Materialtype']")]
                },
                line: {
                    SelType: "FromUrl",
                    SelFrom: "/HomeRedis/GetBaseInfoByKey?key=base_line",
                    SelLabel: "LineName",
                    SelValue: "LineCode",
                    Dom: [$("select[name='lineCode1']"), $("select[name='lineCode2']")]
                },
                //返回的数据 用于后续操作
                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.methods.initFrom();
            app.registerEvent();
        }
    };
    app.init();
});