czt
2025-05-28 3c334646ba738745d9421abfd984178cf7f15691
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
<!DOCTYPE html>
<html lang="zh" xmlns:th="http://www.thymeleaf.org" xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
<head>
    <th:block th:include="include :: header('角色分配用户')" />
</head>
<body class="gray-bg">
    <div class="container-div">
        <div class="row">
            <div class="col-sm-12 search-collapse">
                <form id="role-form">
                    <input type="hidden" id="roleId" name="roleId" th:value="${role.roleId}">
                    <div class="select-list">
                        <ul>
                            <li>
                                登录名称:<input type="text" name="loginName"/>
                            </li>
                            <li>
                                手机号码:<input type="text" name="phonenumber"/>
                            </li>
                            <li>
                                <a class="btn btn-primary btn-rounded btn-sm" onclick="$.table.search()"><i class="fa fa-search"></i>&nbsp;搜索</a>
                                <a class="btn btn-warning btn-rounded btn-sm" onclick="$.form.reset()"><i class="fa fa-refresh"></i>&nbsp;重置</a>
                            </li>
                        </ul>
                    </div>
                </form>
            </div>
            
            <div class="btn-group-sm" id="toolbar" role="group">
                <a class="btn btn-success" onclick="selectUser()" shiro:hasPermission="system:role:add">
                    <i class="fa fa-plus"></i> 添加用户
                </a>
                <a class="btn btn-danger multiple disabled" onclick="cancelAuthUserAll()" shiro:hasPermission="system:role:remove">
                    <i class="fa fa-remove"></i> 批量取消授权
                </a>
                <a class="btn btn-warning" onclick="closeItem()">
                    <i class="fa fa-reply-all"></i> 关闭
                </a>
            </div>
            
            <div class="col-sm-12 select-table table-striped">
                <table id="bootstrap-table"></table>
            </div>
        </div>
    </div>
    <th:block th:include="include :: footer" />
    <script th:inline="javascript">
        var removeFlag = [[${@permission.hasPermi('system:role:remove')}]];
        var datas = [[${@dict.getType('sys_normal_disable')}]];
        var prefix = ctx + "system/role/authUser";
 
        $(function() {
            var options = {
                url: prefix + "/allocatedList",
                queryParams: queryParams,
                sortName: "createTime",
                sortOrder: "desc",
                columns: [{
                    checkbox: true
                },
                {
                    field: 'userId',
                    title: '用户ID',
                    visible: false
                },
                {
                    field: 'loginName',
                    title: '登录名称',
                    sortable: true
                },
                {
                    field: 'userName',
                    title: '用户名称'
                },
                {
                    field: 'email',
                    title: '邮箱'
                },
                {
                    field: 'phonenumber',
                    title: '手机'
                },
                {
                    field: 'status',
                    title: '用户状态',
                    align: 'center',
                    formatter: function (value, row, index) {
                        return $.table.selectDictLabel(datas, value);
                    }
                },
                {
                    field: 'createTime',
                    title: '创建时间',
                    sortable: true
                },
                {
                    title: '操作',
                    align: 'center',
                    formatter: function(value, row, index) {
                        var actions = [];
                        actions.push('<a class="btn btn-danger btn-xs ' + removeFlag + '" href="javascript:void(0)" onclick="cancelAuthUser(\'' + row.userId + '\')"><i class="fa fa-remove"></i>取消授权</a> ');
                        return actions.join('');
                    }
                }]
            };
            $.table.init(options);
        });
        
        function queryParams(params) {
            var search = $.table.queryParams(params);
            search.roleId = $("#roleId").val();
            return search;
        }
        
        /* 分配用户-选择用户 */
        function selectUser() {
            var url = prefix + '/selectUser/' + $("#roleId").val();
            $.modal.open("选择用户", url);
        }
        
        /* 分配用户-批量取消授权 */
        function cancelAuthUserAll(userId) {
            var rows = $.table.selectFirstColumns();
               if (rows.length == 0) {
                   $.modal.alertWarning("请至少选择一条记录");
                   return;
               }
               $.modal.confirm("确认要删除选中的" + rows.length + "条数据吗?", function() {
                var data = { "roleId": $("#roleId").val(), "userIds": rows.join() };
                $.operate.submit(prefix + "/cancelAll", "post", "json", data);
            });
        }
        
        /* 分配用户-取消授权 */
        function cancelAuthUser(userId) {
            $.modal.confirm("确认要取消该用户角色吗?", function() {
                $.operate.post(prefix + "/cancel", { "roleId": $("#roleId").val(), "userId": userId });
            })
        }
    </script>
</body>
</html>