ApiNestingHead.js 12.7 KB
let action = null;
layui.config({
    base: "/js/",
    version: 1
}).use(['system'], function () {
    var form = layui.form,
        $ = layui.jquery,
        element = layui.element,
        table = layui.table,
        system = layui.system,
        sysU = new system.u(),
        sendDataWhere = null,
        sendDataDescWhere = null,
        fatherParam = {},
        areaName = "Material",
        controllerName = "ApiNestingHead",
        app = null;

    action = {
        addOptions: function () {
            var options = {
                fromId: "#modifyForm form",
                url: `/${areaName}/${controllerName}/Ins`,
                //sendDataWhere: null,
                //isAddWhereExtend: "arbitrarily",
                //mainTable: app.data.tableIns,
                submit: "submit(fromAdd)"
            }
            return options;
        },

        editOptions: function () {
            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,
                sendDataWhere: {},
                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`,
                sendDataWhere: {},
                mainTable: app.data.tableIns
            }
            return options;
        },
        rowClickOptions: function () {
            var options = {
                //是否主子表
                isDefault: true,
                targetTableId: app.data.tableElem,
                tabfilter: "tableTabBody",
                tabId: 2,
                customFn: app.methods.initTableDesc
            }
            return options;
        },

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

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

        checkboxMethod: function (obj) {
            //if (!sysU.SetTableRadioCheckBefore()) return;
            var page = "".GetUrlParam("page"),
                xxx = "".GetUrlParam("xxx");
            if (page == "xxx") {
                var sendData = {

                };
                var ajaxConfig = {
                    data: sendData,
                    url: `${areaName}/${controllerName}/xxx`,
                    success: function (result) {
                        if (sysU.successBefore(result)) return false;
                        layer.msg(result.Message);
                    }
                };
                sysU.ajax(ajaxConfig);
            }
        },
        radioMethod: function (obj) {
            if (!sysU.SetTableRadioCheckBefore()) return;

            if (false) {
                var sendData = {
                    xyz: "xx",
                    checkeds: obj.checked,
                    keys: obj.data.keys,
                };
                if (sendData.keys == null || sendData.keys == "") {
                    layer.alert("tableRowOneClick:项目角色标识【keys】为空,请重新关闭后再操作,反复出现请联系管理员", { icon: 2, shadeClose: true, title: "提示" });
                    return false;
                }
                var ajaxConfig = {
                    data: sendData,
                    url: "/base/xxx/xxx",
                    success: function (result) {
                        if (sysU.successBefore(result)) return false;
                        layer.msg(result.Message);
                        sysU.refreshTable(app, sysU, null, "main");
                    }
                };
                sysU.ajax(ajaxConfig);
            }
        },
        CancelExecute: function (sysU, toolbarId, obj) {
            var checkStatus = table.checkStatus(toolbarId);
            if (checkStatus.data.length == 0) {
                layer.alert(sysU.config.titleSelectOne, { icon: sysU.config.iconoError, shadeClose: true, title: sysU.config.titleSelectOneRowData });
                return;
            }
            var Ids = [];
            checkStatus.data.forEach(item => {
                Ids.push(item.id);
            });

            layer.confirm('是否作废套料方案?', { icon: 3, title: '提示' }, function (index) {
                var ajaxConfig = {
                    data: { ids: Ids },
                    url: `/${areaName}/${controllerName}/CancelExecute`,
                    success: function (result) {
                        if (sysU.successBefore(result)) return;
                        layer.msg(result.Message, { icon: sysU.config.iconoOk, shade: 0.4, time: 1000 });
                        action.actionSuccess(app.data.tableElem, app.data.tableIns.config.page.curr);
                    }
                };
                sysU.ajax(ajaxConfig);
            });
        },
        ConfirmExecute: function (sysU, toolbarId, obj) {
            var checkStatus = table.checkStatus(toolbarId);
            if (checkStatus.data.length == 0) {
                layer.alert(sysU.config.titleSelectOne, { icon: sysU.config.iconoError, shadeClose: true, title: sysU.config.titleSelectOneRowData });
                return;
            }
            var Ids = [];
            checkStatus.data.forEach(item => {
                Ids.push(item.id);
            });  
             
            layer.confirm('是否确认添加到套料方案?', { icon: 3, title: '提示' }, function (index) {
                var ajaxConfig = {
                    data: { ids:Ids},
                    url: `/${areaName}/${controllerName}/ConfirmExecute`,
                    success: function (result) {
                        if (sysU.successBefore(result)) return;
                        layer.msg(result.Message, { icon: sysU.config.iconoOk, shade: 0.4, time: 1000 });
                        action.actionSuccess(app.data.tableElem, app.data.tableIns.config.page.curr);
                    }
                };
                sysU.ajax(ajaxConfig);
            });
        },

        //所有动作成功之后
        actionSuccess: (flag) => {
            debugger
            sysU.refreshTable(app, sysU, null, flag);
        },
        closeAfter: function (callBack) {
            if (callBack != null) callBack();
        }
    }

    app = {
        data: {
            cols: [[
                { checkbox: true, fixed: true },
                { field: "id", width: 80, hide: true, title: "Id" },
               // { field: "keys", width: 80, hide: true, title: "Keys" },
                { field: "materielCode", width: 150, title: "物资编码" },
                { field: "materialName", width: 200, title: "物资名称" },
                { field: "pipeSN", width: 120, title: "管材编码" },
                { field: "pipeLength", width: 100, title: "原料长度" },
                { field: "oddmentsLength", width: 100, title: "余料长度" },
                { field: "lineCode", width: 80, title: "产线" },
                { field: "level", width: 80, title: "生产顺序" },
                { field: "state", width: 100, title: "确认状态", templet: function (d) { return "".GetState(window.top.EnumProPlan, d.state) } },
                { field: "createTime", width: 150, title: "下发时间" },
                //{ field: "createBy", width: 150, title: "createBy" },
                { field: "updateTime", width: 150, title: "确认时间" },
                { field: "updateBy", width: 100, title: "确认人" },
                { field: "source", width: 100, title: "来源系统" },
            ]],
            colsDesc: [[
                { checkbox: true, fixed: true },
                { field: "id", width: 80, hide: true, title: "Id" },
                { field: "headKeys", width: 150, title: "headKeys" },
                { field: "barCode", width: 150, title: "工件编号" },
                { field: "cutLength", width: 80, title: "切断长" },
                { field: "flowOrientation", width: 80, title: "流向码" },
                { field: "level", width: 80, title: "切割顺序" },
                { field: "workOrderCode", width: 150, title: "工单号" },
                { field: "pipePartsNo", width: 200, title: "管件号" },
                { field: "assemblageInfo", width: 150, title: "组立信息" },     
                { field: "paintCode", width: 80, title: "涂装代码" },   
                { field: "bevels1", width: 80, title: "坡口1" },
                { field: "bevels2", width: 80, title: "坡口2" },  
                { field: "location", width: 150, title: "打码起始位置" }
            ]],
            tableIns: null,
            tableElem: "mainList",
            tableInsDesc: null,
            tableElemDesc: "mainListDesc",

            //下拉框配置
            selectOption: {
                lineCode: {
                    SelType: "FromUrl",
                    SelFrom: "/HomeRedis/GetBaseInfoByKey?key=base_line",
                    SelLabel: "LineName",
                    SelValue: "LineCode",
                    Dom: [$("[name='lineCode']")]
                },
                //返回的数据 用于后续操作
                selectData: {

                }
            },
            //下拉框配置枚举
            selectOptionEnum: {
                type: {
                    SelValue: "value",     //key or value
                    SelFrom: "dataSource", //固定
                    Dom: [$("select[name='state']")],
                    dataSource: window.top.EnumProPlan,
                },
                //返回的数据 用于后续操作
                selectData: {

                }
            },
        },
        methods: {
            initTable: function (opt) {
                var config = {};
                if (opt != undefined) $.extend(config, opt);
                let options = {
                    elem: "#" + app.data.tableElem,
                    url: `/${areaName}/${controllerName}/Load`,
                    cols: sysU.columnRecord(app.data.tableElem, app.data.cols),
                    toolbar: '#toolbarTable',
                    where: config,
                    //height: "full-56",//如果是主明细页签,列表主体高度要设置,否则分页导航不直观展示
                    doneExtend: function (res, obj) {

                    }
                }
                app.data.tableIns = sysU.initTable(options);
            },
            initTableDesc: function (obj) {
                sendData = { keys: obj.data.keys }
                let opt = {
                    cols: sysU.columnRecord(app.data.tableElemDesc, app.data.colsDesc),
                    elem: "#" + app.data.tableElemDesc,
                    url: `/${areaName}/${controllerName}/LoadDesc`,
                    height: 'full-55',
                    toolbar: '#toolbarTableDesc',
                    limit: 0,
                    page: false,
                    where: sendData
                }
                app.data.tableInsDesc = sysU.initTable(opt);
            },
            initFrom() {
                 sysU.initSelect(app.data.selectOption);
                //sysU.initSelecteByEnum(app.data.selectOptionEnum);
            }
        },
        registerEvent: function () {

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