index.vue 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. <template>
  2. <div class="padding-20">
  3. <div class="search-box">
  4. <el-form ref="form" :inline="true" :model="searchForm" clearable label-width="100px" class="mt-10">
  5. <el-form-item label="创建时间:">
  6. <el-date-picker
  7. :editable="false"
  8. v-model="time"
  9. @change="timearr => {timearr ? (searchForm.start_time = timearr[0] + ' 00:00:00', searchForm.end_time = timearr[1] + ' 23:59:59') : searchForm.start_time = searchForm.end_time = undefined}"
  10. type="daterange"
  11. value-format="yyyy-MM-dd"
  12. start-placeholder="开始时间"
  13. end-placeholder="结束时间"
  14. ></el-date-picker>
  15. </el-form-item>
  16. <el-form-item label="用户姓名:">
  17. <el-input v-model="searchForm.user_full_name" placeholder="请输入用户姓名" clearable></el-input>
  18. </el-form-item>
  19. <el-form-item class="ml-10">
  20. <el-button icon="el-icon-search" type="primary" @click="searchSubmit">查询</el-button>
  21. </el-form-item>
  22. <el-form-item class="ml-10">
  23. <el-button icon="el-icon-plus" type="primary" @click="add" v-permission="'user_list_add'">新增</el-button>
  24. </el-form-item>
  25. </el-form>
  26. </div>
  27. <el-table :data="tableData" stripe v-loading="tableLoading" fit class="marginT-10 order-table" border>
  28. <el-table-column label="工号" prop="id" width="60"></el-table-column>
  29. <el-table-column label="账号" prop="user_name" width="140"></el-table-column>
  30. <el-table-column label="姓名" prop="user_full_name" width="140"></el-table-column>
  31. <el-table-column label="是否管理员" prop="is_admin"
  32. :formatter="row => row.is_admin == 1 ? '管理员' : '普通账号'"
  33. width="120"></el-table-column>
  34. <el-table-column label="创建时间" prop="created_at" width="160"></el-table-column>
  35. <el-table-column label="所属项目" prop="user_project_name" width="140"></el-table-column>
  36. <el-table-column label="所属部门" prop="user_department_name" width="140"></el-table-column>
  37. <el-table-column label="所属角色" prop="user_role_name" width="140"></el-table-column>
  38. <el-table-column label="手机号" prop="user_phone" width="110"></el-table-column>
  39. <el-table-column label="邮箱" prop="user_email" width="200"></el-table-column>
  40. <el-table-column label="操作" width="160" fixed="right">
  41. <template slot-scope="scope">
  42. <el-button type="text" @click="edit(scope.row)" v-permission="'user_list_edit'">编辑</el-button>
  43. <el-button type="text" @click="modPassword(scope.row)" v-permission="'user_list_del'">修改密码</el-button>
  44. <el-button type="text" @click="del(scope.row)" v-permission="'user_list_del'">删除</el-button>
  45. </template>
  46. </el-table-column>
  47. </el-table>
  48. <el-pagination
  49. class="marginT-20"
  50. @size-change="handleSizeChange"
  51. @current-change="handleCurrentChange"
  52. :hide-on-single-page="true"
  53. :current-page="page"
  54. :page-size="page_size"
  55. :page-sizes="[10, 20, 100, 200, 300, 400]"
  56. background
  57. layout="total, sizes, prev, pager, next, jumper"
  58. :total="totalCount"/>
  59. <detail v-if="detailsDialog.show" v-model="detailsDialog.show" :exData="detailsDialog.exData"
  60. @success="init"></detail>
  61. </div>
  62. </template>
  63. <script>
  64. import page from '@/mixin/page'
  65. import detail from './details'
  66. export default {
  67. mixins: [page],
  68. components: {
  69. detail,
  70. },
  71. data () {
  72. return {
  73. detailsDialog: {
  74. show: false,
  75. exData: {}
  76. },
  77. time: [],
  78. searchForm: {},
  79. tableData: [],
  80. tableUrl: '/user/list'
  81. }
  82. },
  83. methods: {
  84. add () {
  85. this.detailsDialog.exData = {}
  86. this.detailsDialog.show = true
  87. },
  88. edit (row) {
  89. this.detailsDialog.exData = row
  90. this.detailsDialog.show = true
  91. },
  92. modPassword (row) {
  93. this.$prompt('请输入新密码', '修改密码', {
  94. confirmButtonText: '确定',
  95. cancelButtonText: '取消',
  96. inputValidator: (value) => {
  97. if (!value || value.replace(/ /g, '').length < 6) {
  98. return false
  99. } else {
  100. return true
  101. }
  102. },
  103. inputErrorMessage: '至少输入6位'
  104. }).then(async ({ value }) => {
  105. const data = await this.$fetch('/api/auth/user/set_user_password', { user_password: value, id: row.id })
  106. if (data.code == 200) {
  107. this.$message.success('修改成功')
  108. }
  109. }).catch(() => {})
  110. },
  111. del (row) {
  112. this.$confirm('确定要删除吗', '确认', {
  113. confirmButtonText: '确定',
  114. cancelButtonText: '取消',
  115. type: 'warning'
  116. }).then(async () => {
  117. const data = await this.$fetch('/api/auth/user/del', { id: row.id })
  118. if (data.code == 200) {
  119. this.$message.success('删除成功')
  120. this.init()
  121. }
  122. }).catch(() => {})
  123. }
  124. },
  125. mounted () {
  126. this.init()
  127. },
  128. }
  129. </script>
  130. <style lang="scss" scoped>
  131. </style>