wmssn.js 11.6 KB
let action = null;
let sendDataWhereTree = {
    correlatedCode: null,
};
layui.config({
    base: "/js/",
    version: 1
}).use(['system', 'ztree', 'table', 'element'], function () {
    var form = layui.form,
        $ = layui.jquery,
        element = layui.element,
        table = layui.table,
        system = layui.system,
        sysU = new system.u(),
        sendDataWhere = null,
        sendDataDescWhere = null,
        areaName = "configure",
        controllerName = "WmsSn",
        app = null;

    action = {
        //导出方法
        exportOptions: function () {
            var options = {
                fromId: "listForm",
                url: `/${areaName}/${controllerName}/Export`,
                isDefault: true,//false导出单表,true导出主明细表
                sendDataWhere: {},
                //后台接口返回数据也要保持一致 response.Result=new{ head=x,body=x、footer=x}
                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) {

        },
        //所有动作成功之后
        actionSuccess: (flag) => {
            var data = null;
            if (flag.includes("Desc")) {
                data = sendDataDescWhere;
            }
            sysU.refreshTable(app, sysU, data, flag);
        },
        closeAfter: function (callBack) {
            if (callBack != null) callBack();
        },
        detailHistory: function (obj) {
            var data = obj.data; //获得当前行数据
            layer.open({
                title: `序列号:[${data.code}]流程记录`,
                type: 2,
                area: ['600px', '500px'],
                content: `Detail?snCode=${data.code}`
            });
        }
    }

    app = {
        data: {
            cols: [[
                //{ checkbox: true, fixed: true },
                { field: "id", width: 80, hide: true, title: "Id" },
                { field: "code", fixed: 'left', title: "SN", width: 130 },
                { field: "correlatedCode", title: "项目号", hide: true },
                { field: "snStatus", title: "SN使用状态", width: 100, templet: '#snStatusTool' },
                { field: "operation", title: "当前节点", width: 100},
                {
                    field: "progress", width: 100, title: "进度条", templet: function (d) {
                        let pro = d.progress;
                        //判断颜色
                        let ys = '';
                        if (30 < pro && pro < 100) {
                            ys = 'layui-bg-blue'
                        } else if (0 < pro && pro <= 30) {
                            ys = 'layui-bg-orange'
                        }
                        //拼接进度条
                        return '<div title="总进度是8步:SN申请、SN授权、SN绑定、SN解绑、SN入库、SN出库、SN推送IOT、IOT使用SN" class="layui-progress layui-progress-big" lay-showpercent="true"><div class="layui-progress-bar ' + ys + '" lay-percent="' + pro + '%"></div></div><br>'
                    }
                },

                {
                    field: "createdBy", width: 150, title: "创建人", templet: function (d) {
                        if (d.userName != null) {
                            return `${d.createdBy} [${d.userName}]`;
                        }
                        return d.createdBy;
                    }
                },
                { field: "created", width: 150, title: "创建时间" },
                { fixed: 'right', title: '查看', width: 85, toolbar: '#tool' }
            ]],
            colsDesc: [[
                { field: "id", width: 80, hide: true, title: "Id" },
                { field: "snId", title: "snId", hide: true },
                { field: "snCode", title: "SN号" },
                { field: "part", title: "部件号" },
                { field: "created", width: 150, title: "创建时间" },
                { field: "createdBy", width: 150, title: "创建人" },
                { field: "created", width: 150, title: "更新时间" },
                { field: "createdBy", width: 150, title: "更新人" },
            ]],
            tableIns: null,
            tableElem: "mainList",
            tableInsDesc: null,
            tableElemDesc: "mainListDesc",

            tree: $("#tree"),
            treeObj: null,
            setting: {
                view: { selectedMulti: false },
                async: {
                    enable: true,
                    url: `/${areaName}/${controllerName}/GetTreeList`,
                    type: "get"
                },
                data: {
                    simpleData: {
                        enable: true,
                        idKey: "keys",
                        pIdKey: "parentId",
                        rootPId: ""
                    }
                },
                callback: {
                    onClick: function (event, treeId, treeNode) {
                        sendDataWhereTree.correlatedCode = treeNode.keys;
                        if (treeNode.keys == 'r-1') {
                            sendDataWhereTree.correlatedCode = null;
                        }
                        else if (treeNode.keys == 'r-2' || treeNode.keys == 'r-3') {
                            return;
                        }
                        app.methods.initTable(sendDataWhereTree);
                        element.tabChange(action.rowClickOptions().tabfilter, 1)
                        if (app.data.tableInsDesc != null) layui.table.reload(app.data.tableElemDesc, { url: '', data: [] })
                    },
                    onAsyncSuccess: function (event, treeId, treeNode, msg) {
                        app.data.treeObj.expandAll(true);
                        $("#tree_4_a").click()
                        ztreeProjectData = JSON.parse(msg)
                    }
                }
            },

            //下拉框配置
            selectOption: {
                //station: {
                //    SelType: "FromUrl",
                //    SelFrom: `/${areaName}/${controllerName}/StationLineSelect`,
                //    SelLabel: "workStationName",
                //    SelValue: "workStationCode",
                //    OptGroup: true,
                //    Dom: [$("[name='stationCode']")]
                //},
                //返回的数据 用于后续操作
                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-52",//如果是主明细页签,列表主体高度要设置,否则分页导航不直观展示
                    doneExtend: function (res, obj) {
                        setTimeout(() => {
                            app.data.tree.height($("div.layui-table-view").height() - 8);
                        }, 50);
                        element.render();
                    }
                }
                app.data.tableIns = sysU.initTable(options);
            },
            initTableDesc: function (obj) {
                debugger
                //查询表单值form.val("listFormDesc")
                sendDataDescWhere = {};
                //主表附加设备值
                sendDataDescWhere["snId"] = obj.data.id;
                let opt = {
                    cols: sysU.columnRecord(app.data.tableElemDesc, app.data.colsDesc),
                    elem: "#" + app.data.tableElemDesc,
                    url: `/${areaName}/${controllerName}/LoadDesc`,
                    height: 'full-52',
                    toolbar: '#toolbarTableDesc',
                    menuModule: controllerName,
                    areaMenus: 2,
                    where: sendDataDescWhere
                }
                app.data.tableInsDesc = sysU.initTable(opt);
            },
            initTree: function () {
                app.data.treeObj = $.fn.zTree.init(app.data.tree, app.data.setting);
            },
            //树节点查询,目前树结构只有一级 所以不需要提供查询
            filterNodes: function (list, searchText) {
                var filterList = [];
                list.forEach((ele) => {
                    if (ele.name.indexOf(searchText) > -1) {
                        filterList.push(ele);
                    }
                });
                return filterList;
            },
            //项目树搜索
            queryProject(searchText) {
                let setting = "".copyObj2(app.data.setting)
                delete setting.async;
                var data = app.methods.filterNodes(ztreeProjectData, searchText)
                $.fn.zTree.init(app.data.tree, setting, data);
                if (data.length > 0) {
                    app.data.treeObj.expandAll(true);
                    var ele = "tree_1_a";
                    if (data.length == ztreeProjectData.length) ele = "tree_2_a";
                    $("#" + ele).click()
                }
            },
            initFrom() {
                //sysU.tabClick("tableTabBody");
            }
        },
        registerEvent: function () {
            $("#queryProjectCode").bind('input propertychange', function () {
                if (app.data.treeObj == null) return;
                var searchText = $(this).val();
                app.methods.queryProject(searchText);
            })
        },
        init: function () {
            app.methods.initFrom();
            //var sendDataWhere = form.val("listForm")
            app.methods.initTable();
            app.methods.initTree();
            app.registerEvent();
        },
    };
    app.init();
});