Users.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469
  1. <!--
  2. * @Description:
  3. * @Version: 1.0
  4. * @Autor: zhuyijun
  5. * @Date: 2021-11-21 21:32:18
  6. * @LastEditTime: 2021-11-22 22:53:50
  7. -->
  8. <template>
  9. <div>
  10. <!-- 面包屑导航区 -->
  11. <el-breadcrumb separator-class="el-icon-arrow-right">
  12. <el-breadcrumb-item :to="{ path: '/home' }">首页</el-breadcrumb-item>
  13. <el-breadcrumb-item>用户管理</el-breadcrumb-item>
  14. <el-breadcrumb-item>用户列表</el-breadcrumb-item>
  15. </el-breadcrumb>
  16. <!-- 卡片式图区域 -->
  17. <el-card>
  18. <!-- 搜索与添加区域 -->
  19. <el-row :gutter="20">
  20. <el-col :span="12">
  21. <el-input placeholder="请输入内容"
  22. class="input-with-select"
  23. v-model="queryInfo.query"
  24. clearable
  25. @clear="getUserList">
  26. <el-button slot="append"
  27. icon="el-icon-search"
  28. @click="getUserList"></el-button>
  29. </el-input>
  30. </el-col>
  31. <el-col :span="4">
  32. <el-button type="primary"
  33. icon="el-icon-user"
  34. @click="addDialogVisible = true">添加用户</el-button>
  35. </el-col>
  36. </el-row>
  37. <!-- 用户列表区 -->
  38. <el-table :data="userList"
  39. border
  40. stripe>
  41. <el-table-column label="序号"
  42. type="index">
  43. </el-table-column>
  44. <el-table-column label="姓名"
  45. prop="username">
  46. </el-table-column>
  47. <el-table-column label="邮箱"
  48. prop="email">
  49. </el-table-column>
  50. <el-table-column label="电话"
  51. prop="mobile">
  52. </el-table-column>
  53. <el-table-column label="角色"
  54. prop="role_name">
  55. </el-table-column>
  56. <el-table-column label="状态">
  57. <template slot-scope="scope">
  58. <el-tooltip effect="dark"
  59. :content="!scope.row.mg_state ?'启用':'禁用'"
  60. placement="top"
  61. :enterable="false">
  62. <el-switch v-model="scope.row.mg_state"
  63. @change="userStateChanegd(scope.row)">
  64. </el-switch>
  65. </el-tooltip>
  66. </template>
  67. </el-table-column>
  68. <el-table-column label="操作"
  69. width="180px">
  70. <template slot-scope="scope">
  71. <!-- 修改按钮 -->
  72. <el-tooltip effect="dark"
  73. content="修改"
  74. placement="top"
  75. :enterable="false">
  76. <el-button type="primary"
  77. icon="el-icon-edit"
  78. size="mini"
  79. @click="showEditDialog(scope.row)"></el-button>
  80. </el-tooltip>
  81. <!-- 删除按钮 -->
  82. <el-tooltip effect="dark"
  83. content="删除"
  84. placement="top"
  85. :enterable="false">
  86. <el-button type="danger"
  87. icon="el-icon-delete"
  88. size="mini"
  89. @click="removeUserById(scope.row.id)"></el-button>
  90. </el-tooltip>
  91. <!-- 分配权限 -->
  92. <el-tooltip effect="dark"
  93. content="分配角色"
  94. placement="top"
  95. :enterable="false">
  96. <el-button type="success"
  97. icon="el-icon-setting"
  98. size="mini"
  99. @click="setRole(scope.row)"></el-button>
  100. </el-tooltip>
  101. </template>
  102. </el-table-column>
  103. </el-table>
  104. <el-pagination @size-change="handleSizeChange"
  105. @current-change="handleCurrentChange"
  106. :current-page="queryInfo.pagenum"
  107. :page-sizes="[2, 5, 10, 20]"
  108. :page-size="queryInfo.pagesize"
  109. layout="total, sizes, prev, pager, next, jumper"
  110. :total="total">
  111. </el-pagination>
  112. </el-card>
  113. <!-- 添加用户对话框 -->
  114. <el-dialog title="添加用户"
  115. :visible.sync="addDialogVisible"
  116. width="50%"
  117. @close="resetAddForm">
  118. <!-- 内容主体区 -->
  119. <el-form :model="addForm"
  120. :rules="addFormRules"
  121. ref="addFormRef"
  122. label-width="70px">
  123. <!-- 用户名称 -->
  124. <el-form-item label="用户名"
  125. prop="username">
  126. <!-- <el-input prefix-icon="iconfont icon-user"></el-input> -->
  127. <el-input v-model="addForm.username"
  128. prefix-icon="el-icon-user"
  129. type="text"></el-input>
  130. </el-form-item>
  131. <!-- 密码 -->
  132. <el-form-item label="密码"
  133. prop="password">
  134. <!-- <el-input prefix-icon="iconfont icon-3702mima"></el-input> -->
  135. <el-input v-model="addForm.password"
  136. prefix-icon="el-icon-lock"
  137. type="password"></el-input>
  138. </el-form-item>
  139. <!-- 邮箱 -->
  140. <el-form-item label="邮箱"
  141. prop="email">
  142. <!-- <el-input prefix-icon="iconfont icon-user"></el-input> -->
  143. <el-input v-model="addForm.email"
  144. prefix-icon="el-icon-user"
  145. type="text"></el-input>
  146. </el-form-item>
  147. <el-form-item label="手机号"
  148. prop="mobile">
  149. <!-- <el-input prefix-icon="iconfont icon-user"></el-input> -->
  150. <el-input v-model="addForm.mobile"
  151. prefix-icon="el-icon-user"
  152. type="text"></el-input>
  153. </el-form-item>
  154. </el-form>
  155. <!-- 底部区 -->
  156. <span slot="footer"
  157. class="dialog-footer">
  158. <el-button @click="addDialogVisible = false">取 消</el-button>
  159. <el-button type="primary"
  160. @click="addUser">确 定</el-button>
  161. </span>
  162. </el-dialog>
  163. <!-- 修改用户的对话框 -->
  164. <el-dialog title="修改用户"
  165. :visible.sync="editDialogVisible"
  166. width="50%"
  167. @close="resetEditForm">
  168. <!-- 内容主体区 -->
  169. <el-form :model="editForm"
  170. :rules="editFormRules"
  171. ref="editFormRef"
  172. label-width="70px">
  173. <!-- 用户名称 -->
  174. <el-form-item label="编号"
  175. prop="id">
  176. <!-- <el-input prefix-icon="iconfont icon-user"></el-input> -->
  177. <el-input v-model="editForm.id"
  178. prefix-icon="el-icon-user"
  179. type="text"
  180. disabled></el-input>
  181. </el-form-item>
  182. <!-- 用户名称 -->
  183. <el-form-item label="用户名"
  184. prop="username">
  185. <!-- <el-input prefix-icon="iconfont icon-user"></el-input> -->
  186. <el-input v-model="editForm.username"
  187. prefix-icon="el-icon-user"
  188. type="text"
  189. disabled></el-input>
  190. </el-form-item>
  191. <!-- 邮箱 -->
  192. <el-form-item label="邮箱"
  193. prop="email">
  194. <!-- <el-input prefix-icon="iconfont icon-user"></el-input> -->
  195. <el-input v-model="editForm.email"
  196. prefix-icon="el-icon-user"
  197. type="text"></el-input>
  198. </el-form-item>
  199. <el-form-item label="手机号"
  200. prop="mobile">
  201. <!-- <el-input prefix-icon="iconfont icon-user"></el-input> -->
  202. <el-input v-model="editForm.mobile"
  203. prefix-icon="el-icon-user"
  204. type="text"></el-input>
  205. </el-form-item>
  206. </el-form>
  207. <span slot="footer"
  208. class="dialog-footer">
  209. <el-button @click="editDialogVisible = false">取 消</el-button>
  210. <el-button type="primary"
  211. @click="editUserInfo()">确 定</el-button>
  212. </span>
  213. </el-dialog>
  214. <!-- 分配角色Dialog对话框 -->
  215. <el-dialog title="分配角色"
  216. :visible.sync="setRoleDialogVisible"
  217. width="50%"
  218. @click="setRoleDialogClosed">
  219. <div>
  220. <p>当前 用户 :{{this.userInfo.username}}</p>
  221. <p>当前 角色 :{{this.userInfo.role_name}}</p>
  222. <p>分配 新角色 :
  223. <el-select v-model="selectedRoleId"
  224. placeholder="请选择">
  225. <el-option v-for="item in rolesList"
  226. :key="item.id"
  227. :label="item.roleName"
  228. :value="item.id">
  229. </el-option>
  230. </el-select>
  231. </p>
  232. </div>
  233. <span slot="footer"
  234. class="dialog-footer">
  235. <el-button @click="editDialogVisible = false">取 消</el-button>
  236. <el-button type="primary"
  237. @click="saveRoleInfo">确 定</el-button>
  238. </span>
  239. </el-dialog>
  240. </div>
  241. </template>
  242. <script>
  243. export default {
  244. data () {
  245. // 验证邮箱规则
  246. var checkEmail = (rule, value, cb) => {
  247. console.log(value)
  248. const regEmail = /^\w{3,15}@[\w-]+\.(com|cn|net|org|edu|com\.cn)$/gi
  249. if (regEmail.test(value)) {
  250. return cb()
  251. }
  252. cb(new Error('请输入合法邮箱'))
  253. }
  254. // 校验手机号
  255. var checkMobile = (rule, value, cb) => {
  256. const regMobile = /1[34578]\d{9}$/g
  257. if (regMobile.test(value)) {
  258. return cb()
  259. }
  260. cb(new Error('请输入合法手机号'))
  261. }
  262. return {
  263. userList: [],
  264. queryInfo: {
  265. query: '',
  266. pagenum: 1,
  267. pagesize: 2
  268. },
  269. total: 0,
  270. addDialogVisible: false,
  271. editDialogVisible: false,
  272. addForm: {
  273. username: '',
  274. password: '',
  275. email: '',
  276. mobile: ''
  277. },
  278. editForm: {
  279. id: '',
  280. username: '',
  281. email: '',
  282. mobile: ''
  283. },
  284. addFormRules: {
  285. // 验证用户名是否合法
  286. username: [
  287. { required: true, message: '请输入登录名称', trigger: 'blur' },
  288. { min: 3, max: 20, message: '长度在 3 到 20 个字符', trigger: 'blur' }
  289. ],
  290. // 验证密码是否合法
  291. password: [
  292. { required: true, message: '请输入密码', trigger: 'blur' },
  293. { min: 6, max: 20, message: '长度在 6到 20 个字符', trigger: 'blur' }
  294. ],
  295. email: [
  296. { required: true, message: '请输入邮箱' },
  297. { validator: checkEmail, trigger: 'blur' }
  298. ],
  299. mobile: [
  300. { required: true, message: '请输入手机号', trigger: 'blur' },
  301. { validator: checkMobile, trigger: 'blur' }
  302. ]
  303. },
  304. editFormRules: {
  305. id: [{ required: true, message: '编号不能为空' }],
  306. email: [
  307. { required: true, message: '请输入邮箱' },
  308. { validator: checkEmail, trigger: 'blur' }
  309. ],
  310. mobile: [
  311. { required: true, message: '请输入手机号', trigger: 'blur' },
  312. { validator: checkMobile, trigger: 'blur' }
  313. ]
  314. },
  315. setRoleDialogVisible: false,
  316. userInfo: {
  317. id: ''
  318. },
  319. //所有角色的数据列表
  320. rolesList: [],
  321. //选种的角色
  322. selectedRoleId: ''
  323. }
  324. },
  325. created () {
  326. this.getUserList()
  327. },
  328. methods: {
  329. async getUserList () {
  330. const { data: res } = await this.$http.get('users', { params: this.queryInfo })
  331. // console.log(res)
  332. if (res.meta.status !== 200) return this.$message.error("数据获取失败")
  333. this.userList = res.data.users
  334. this.total = res.data.total
  335. },
  336. // 监听pagesize值改变事件
  337. handleSizeChange (newSize) {
  338. this.queryInfo.pagesize = newSize
  339. this.getUserList()
  340. },
  341. // 监听页码值改变的事件
  342. handleCurrentChange (newPage) {
  343. this.queryInfo.pagenum = newPage
  344. this.getUserList()
  345. },
  346. async userStateChanegd (userinfo) {
  347. const { data: res } = await this.$http.put(`users/${userinfo.id}/state/${userinfo.mg_state}`)
  348. if (res.meta.status !== 200) {
  349. return this.$message.error('更新用户状态失败')
  350. }
  351. this.$message.success('更新用户状态成功')
  352. },
  353. // 重置表单 dialog监听关闭事件
  354. resetAddForm () {
  355. this.$refs.addFormRef.resetFields()
  356. },
  357. resetEditForm () {
  358. this.$refs.editFormRef.resetFields()
  359. },
  360. // 点击按钮,添加新用户
  361. addUser () {
  362. this.$refs.addFormRef.validate(async valid => {
  363. if (!valid) return
  364. // 可以发起添加用户的网络请求
  365. const { data: res } = await this.$http.post('users', this.addForm)
  366. if (res.meta.status !== 201) {
  367. this.$message.error('添加用户失败!')
  368. }
  369. this.$message.success('添加用户成功!')
  370. // 隐藏添加用户的对话框
  371. this.addDialogVisible = false
  372. // 重新获取用户列表数据
  373. this.getUserList()
  374. })
  375. },
  376. async showEditDialog (userinfo) {
  377. this.editForm = userinfo
  378. this.editDialogVisible = true
  379. },
  380. editUserInfo () {
  381. this.$refs.editFormRef.validate(async (vaild) => {
  382. if (!vaild) return
  383. // 发起修改用户请求
  384. const { data: res } = await this.$http.put(`users/${this.editForm.id}`, {
  385. email: this.editForm.email,
  386. mobile: this.editForm.mobile
  387. })
  388. if (res.meta.status !== 200) {
  389. return this.$message.error('用户修改失败')
  390. }
  391. this.$message.success('用户修改成功')
  392. // 隐藏添加用户的对话框
  393. this.editDialogVisible = false
  394. // 重新获取用户列表数据
  395. this.getUserList()
  396. })
  397. },
  398. async removeUserById (id) {
  399. const confirmResule = await this.$confirm('此操作将永久删除该用户, 是否继续?', '提示', {
  400. confirmButtonText: '确定',
  401. cancelButtonText: '取消',
  402. type: 'warning'
  403. }).catch(err => err)
  404. // 用户确认删除,返回字符串 confirm
  405. // 用户取消删除返回字符串 chancel
  406. if (confirmResule !== 'confirm') {
  407. return this.$message.info('已经取消删除')
  408. }
  409. const { data: res } = await this.$http.delete(`users/${id}`)
  410. if (res.meta.status != 200) {
  411. return this.$message.error('删除失败')
  412. }
  413. this.getUserList()
  414. this.$message.success('删除成功')
  415. },
  416. async setRole (userInfo) {
  417. this.userInfo = userInfo
  418. if (this.rolesList.length == 0) {
  419. //获取所有角色列表
  420. const { data: res } = await this.$http.get('roles')
  421. if (res.meta.status != 200) {
  422. return this.$message.error('获取角色列表失败')
  423. }
  424. this.rolesList = res.data
  425. }
  426. this.setRoleDialogVisible = true
  427. },
  428. setRoleDialogClosed () {
  429. this.userList = []
  430. this.selectedRoleId = ''
  431. },
  432. async saveRoleInfo () {
  433. if (!this.selectedRoleId) {
  434. return this.$message.error('请选择要分配的角色!')
  435. }
  436. const { data: res } = await this.$http.put(`users/${this.userInfo.id}/role`, { rid: this.selectedRoleId })
  437. if (res.meta.status !== 200) {
  438. return this.$message.error(res.meta.msg)
  439. }
  440. this.getUserList()
  441. this.setRoleDialogVisible = false
  442. return this.$message.success(res.meta.msg)
  443. }
  444. }
  445. }
  446. </script>
  447. <style lang="less" scoped>
  448. .el-table {
  449. margin-top: 15px;
  450. font-size: 12px;
  451. }
  452. .el-pagination {
  453. margin-top: 15px;
  454. }
  455. </style>