menu.html 7.49 KB
<!DOCTYPE html>
<html lang="zh" xmlns:th="http://www.thymeleaf.org">
<meta charset="utf-8">
<head th:include="include :: header"></head>
<body class="gray-bg">
<div class="container-div">
    <div class="row">
        <div class="col-sm-12 select-info">
            <form id="menu-form" autocomplete="off">
                <div class="select-list">
                    <ul>
                        <li>
                            <label>菜单名称:</label>
                            <input name="menuName" placeholder="请输入菜单名称" type="text"/>
                        </li>
                        <li>
                            <label>菜单状态:</label>
                            <select name="visible" th:with="type=${@dict.getType('sys_show_hide')}">
                                <option value="">所有</option>
                                <option th:each="e : ${type}" th:text="${e['dictLabel']}"
                                        th:value="${e['dictValue']}">
                                </option>
                            </select>
                        </li>
                        <li style="float: right; margin-right: 45px">
                            <a class="btn btn-primary btn-rounded btn-sm" onclick="$.treeTable.search()">
                                <i class="fa fa-search"></i>&nbsp;搜索
                            </a>
                            <a class="btn btn-warning btn-rounded btn-sm" onclick="$.form.reset('menu-form')">
                                <i class="fa fa-refresh"></i>&nbsp;重置
                            </a>
                        </li>
                    </ul>
                </div>
            </form>
        </div>

        <div class="btn-group hidden-xs" id="toolbar" role="group">
            <a class="btn btn-outline btn-success btn-rounded" onclick="$.operate.add(0)"
               shiro:hasPermission="system:menu:add">
                <i class="fa fa-plus"></i> 新增
            </a>
        </div>
        <div class="col-sm-12 select-table">
            <table id="bootstrap-table" data-mobile-responsive="true" class="table table-bordered table-hover"></table>
        </div>
    </div>
</div>

<div th:include="include :: footer"></div>
<script th:inline="javascript">
    var addFlag = [[${@permission.hasPermi('system:menu:add')}]];
    var editFlag = [[${@permission.hasPermi('system:menu:edit')}]];
    var removeFlag = [[${@permission.hasPermi('system:menu:remove')}]];
    var datas = [[${@dict.getType('sys_show_hide')}]];
    var prefix = ctx + "system/menu"

    $(function () {
        var options = {
            id: "bootstrap-table",
            code: "id",
            uniqueId: "id",
            parentCode: "parentId",
            expandAll: false,
            expandFirst: false,
            url: prefix + "/list",
            createUrl: prefix + "/add/{id}",
            updateUrl: prefix + "/edit/{id}",
            removeUrl: prefix + "/remove/{id}",
            modalName: "菜单",
            columns: [
                {
                    field: 'selectItem',
                    radio: true
                }, {
                    title: '菜单名称',
                    field: 'menuName',
                    width: '20%',
                    formatter: function (value, row, index) {
                        if (row.icon == null || row == "") {
                            return row.menuName;
                        } else {
                            return '<i class="' + row.icon + '"></i> <span class="nav-label">' + row.menuName + '</span>';
                        }
                    }
                },
                {
                    field: 'orderNum',
                    title: '排序',
                    width: '6%',
                    align: "left"
                },
                {
                    field: 'url',
                    title: '请求地址',
                    width: '15%',
                    align: "center"
                },
                {
                    title: '类型',
                    field: 'menuType',
                    width: '10%',
                    align: "center",
                    formatter: function (value, item, index) {
                        if (item.menuType == 'M') {
                            return '<span class="label label-success">目录</span>';
                        } else if (item.menuType == 'C') {
                            return '<span class="label label-primary">菜单</span>';
                        } else if (item.menuType == 'F') {
                            return '<span class="label label-warning">按钮</span>';
                        }
                    }
                },
                {
                    field: 'menuMobile',
                    title: '手机端',
                    width: '7%',
                    align: "center",
                    formatter: function (value, item, index) {
                        if (value == true) {
                            return '<span class="badge" style="background-color: #00B83F;color: white;width: 36px;">' + ' 是 ' + '</span>';
                        } else if (value == false) {
                            return '<span class="badge" style="background-color: #ac2925;color: white;width: 36px;">' + ' 否 ' + '</span>';
                        }
                    }
                },
                {
                    field: 'visible',
                    title: '可见',
                    width: '7%',
                    align: "center",
                    formatter: function (value, row, index) {
                        return $.table.selectDictLabel(datas, row.visible);
                    }
                },
                {
                    field: 'perms',
                    title: '权限标识',
                    width: '15%',
                    align: "center",
                    formatter: function (value, row, index) {
                        return $.table.tooltip(value);
                    }
                },
                {
                    title: '操作',
                    width: '20%',
                    align: "center",
                    formatter: function (value, row, index) {
                        var actions = [];
                        actions.push('<a class="btn btn-success btn-xs ' + editFlag + '" href="#" onclick="$.operate.edit(\'' + row.id + '\')"><i class="fa fa-edit"></i>编辑</a> ');
                        actions.push('<a class="btn btn-info btn-xs ' + addFlag + '" href="#" onclick="$.operate.add(\'' + row.id + '\')"><i class="fa fa-plus"></i>新增</a> ');
                        actions.push('<a class="btn btn-danger btn-xs ' + removeFlag + '" href="#" onclick="$.operate.remove(\'' + row.id + '\')"><i class="fa fa-trash-o"></i>删除</a>');
                        return actions.join('');
                    }
                }]
        };
        $.treeTable.init(options);
    });

    function remove(id) {
        $.modal.confirm("确定删除该条" + $.table._option.modalName + "信息吗?", function () {
            $.ajax({
                type: 'post',
                url: prefix + "/remove/" + id,
                success: function (result) {
                    if (result.code == web_status.SUCCESS) {
                        $.modal.alertSuccess(result.msg);
                        $.treeTable.refresh();
                    } else {
                        $.modal.alertError(result.msg);
                    }
                }
            });
        });
    }
</script>
</body>
</html>