sysapp.js 4.69 KB

let action = null;
layui.config({
    base: "/js/",
    version: 1222
}).use(['system'], function () {
    var form = layui.form,
        $ = layui.jquery,
        element = layui.element,
        table = layui.table,
        system = layui.system,
        sysU = new system.u(),
        areaName = "base",
        tableName = "SysApp",
        app = null;

    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`,
                content: $("#modifyForm"),
                submit: "submit(fromUpdate)"
            }
            return options;
        },


        deleteOptions: function () {
            var options = {
                url: `/${areaName}/${tableName}/DelByIds`,
                keyId: "id"
            }
            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;
        },

        uploadSaveBefore: function (formData, selectRow, callBack) {
			var fromValue = form.val(formData.parm.content[0].id);
            console.log(fromValue);
            delete fromValue.excelfile;

            var keys = Object.keys(fromValue);
            for (var item in keys) {
                if (!Object.prototype.hasOwnProperty.call(keys, item)) continue;
                var closName = keys[item],
                    val = fromValue[closName];      
                formData.formFile.append(closName, val);
            }

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

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

        //所有动作成功之后
        actionSuccess: (flag) => {
            sysU.refreshTable(app, sysU, null, flag);
       }
    }
    app = {
        data: {
            cols: [[
                { checkbox: true, fixed: true },
                { field: 'id', width: 80,  hide: true, title: 'id' },
                { field: 'keys', width: 180, hide: true, title: 'keys' },
                { field: 'appId', width: 150, title: '应用标识' },
                { field: 'ver', width: 100, title: '版本号' },
                { field: 'fileName', width: 180,  title: '文件名称' },
                {
                    field: 'filePath', width: 500,  title: 'Url', templet: function (d) {
                        return `<a href="${d.filePath}" class="layui-table-link" target="_blank">${d.filePath}</a>`;
                    }
                },
                { field: 'createBy', width: 150, title: '创建用户' },
                { field: 'createTime', width: 150,  title: '创建时间' },
            ]],
            tableIns: null,
            tableElem: "mainList",

            selectOption: {
   
                //返回的数据 用于后续操作
                selectData: {

                }
            }

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

        },

        init: function () {
            sysU.initSelect(app.data.selectOption);
            app.methods.initTable();
            app.registerEvent();
        }
    };

    app.init();

})