AdminUserManage.vue 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. <template>
  2. <div class="user-manage">
  3. <div class="part-box part-box-filter part-box-flex">
  4. <el-form ref="FilterForm" label-position="left" label-width="85px" inline>
  5. <el-form-item label="姓名:" label-width="75px">
  6. <el-input
  7. style="width: 142px;"
  8. v-model.trim="filter.realName"
  9. placeholder="姓名"
  10. clearable
  11. ></el-input>
  12. </el-form-item>
  13. <el-form-item label="启用/禁用:" label-width="90px">
  14. <el-select
  15. v-model="filter.enable"
  16. style="width: 110px;"
  17. placeholder="启用/禁用"
  18. clearable
  19. >
  20. <el-option
  21. v-for="(val, key) in ABLE_TYPE"
  22. :key="key"
  23. :value="key * 1"
  24. :label="val"
  25. ></el-option>
  26. </el-select>
  27. </el-form-item>
  28. <el-form-item label-width="0px">
  29. <el-button type="primary" @click="toPage(1)">查询</el-button>
  30. </el-form-item>
  31. </el-form>
  32. <div class="part-box-action">
  33. <el-button
  34. type="primary"
  35. icon="el-icon-circle-plus-outline"
  36. @click="toAdd"
  37. >新增用户</el-button
  38. >
  39. </div>
  40. </div>
  41. <div class="part-box part-box-pad">
  42. <el-table ref="TableList" :data="users">
  43. <el-table-column
  44. type="index"
  45. label="序号"
  46. width="70"
  47. :index="indexMethod"
  48. ></el-table-column>
  49. <el-table-column prop="loginName" label="用户名"></el-table-column>
  50. <el-table-column prop="realName" label="姓名"></el-table-column>
  51. <el-table-column prop="roles" label="角色">
  52. <template slot-scope="scope">
  53. {{ scope.row.roles | rolesFilter }}
  54. </template>
  55. </el-table-column>
  56. <el-table-column prop="mobileNumber" label="手机号"></el-table-column>
  57. <el-table-column prop="enable" label="状态" width="100">
  58. <template slot-scope="scope">
  59. {{ scope.row.enable | enableFilter }}
  60. </template>
  61. </el-table-column>
  62. <el-table-column class-name="action-column" label="操作" width="120px">
  63. <template slot-scope="scope">
  64. <el-button
  65. class="btn-primary"
  66. type="text"
  67. @click="toEdit(scope.row)"
  68. >编辑</el-button
  69. >
  70. <el-button
  71. :class="scope.row.enable ? 'btn-danger' : 'btn-primary'"
  72. type="text"
  73. @click="toEnable(scope.row)"
  74. >{{ scope.row.enable ? "禁用" : "启用" }}</el-button
  75. >
  76. <el-button
  77. class="btn-danger"
  78. type="text"
  79. @click="toResetPwd(scope.row)"
  80. >重置密码</el-button
  81. >
  82. </template>
  83. </el-table-column>
  84. </el-table>
  85. <div class="part-page">
  86. <el-pagination
  87. background
  88. layout="total,prev, pager, next"
  89. :current-page="current"
  90. :total="total"
  91. :page-size="size"
  92. @current-change="toPage"
  93. >
  94. </el-pagination>
  95. </div>
  96. </div>
  97. <!-- ModifyUser -->
  98. <modify-user
  99. ref="ModifyUser"
  100. :instance="curUser"
  101. :roles="roles"
  102. @modified="getList"
  103. ></modify-user>
  104. </div>
  105. </template>
  106. <script>
  107. import ModifyUser from "../components/ModifyUser";
  108. import { ABLE_TYPE } from "@/constants/enumerate";
  109. import { userListPage, ableUser, resetPwd, userRoleListPage } from "../api";
  110. export default {
  111. name: "user-manage",
  112. components: { ModifyUser },
  113. data() {
  114. return {
  115. filter: {
  116. realName: "",
  117. enable: ""
  118. },
  119. current: 1,
  120. size: this.GLOBAL.pageSize,
  121. total: 0,
  122. visible: false,
  123. ABLE_TYPE,
  124. roles: [],
  125. users: [],
  126. curUser: {}
  127. };
  128. },
  129. created() {
  130. this.getRoleList();
  131. this.getList();
  132. },
  133. methods: {
  134. async getRoleList() {
  135. const data = await userRoleListPage();
  136. this.roles = data || [];
  137. this.roles = this.roles
  138. .filter(item => item.type !== "ADMIN")
  139. .map(item => {
  140. return {
  141. id: item.id,
  142. name: item.name
  143. };
  144. });
  145. },
  146. async getList() {
  147. const datas = {
  148. ...this.filter,
  149. pageNumber: this.current,
  150. pageSize: this.size
  151. };
  152. if (datas.enable !== null && datas.enable !== "")
  153. datas.enable = !!datas.enable;
  154. const data = await userListPage(datas);
  155. this.users = data.records;
  156. this.total = data.total;
  157. },
  158. toPage(page) {
  159. this.current = page;
  160. this.getList();
  161. },
  162. toEnable(row) {
  163. // 自己不可以启用/禁用自己
  164. const userId = this.$ls.get("user", { id: "" }).id;
  165. if (row.id === userId) {
  166. this.$message.error("不可以启用/禁用自己!");
  167. return;
  168. }
  169. const action = row.enable ? "禁用" : "启用";
  170. this.$confirm(`确定要${action}用户【${row.realName}】吗?`, "提示", {
  171. type: "warning"
  172. })
  173. .then(async () => {
  174. const enable = !row.enable;
  175. await ableUser({
  176. id: row.id,
  177. enable
  178. });
  179. row.enable = enable;
  180. this.$message.success("操作成功!");
  181. })
  182. .catch(() => {});
  183. },
  184. toEdit(row) {
  185. this.curUser = row;
  186. this.$refs.ModifyUser.open();
  187. },
  188. toAdd() {
  189. this.curUser = {};
  190. this.$refs.ModifyUser.open();
  191. },
  192. async toResetPwd(row) {
  193. await resetPwd(row.id);
  194. this.$message.success("密码重置成功!");
  195. }
  196. }
  197. };
  198. </script>