user.vue 8.8 KB
Newer Older
1 2
<template>
  <div>
P
piexlmax 已提交
3
    <div class="gva-btn-list">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
4
      <el-button size="mini" type="primary" icon="el-icon-plus" @click="addUser">新增用户</el-button>
5
    </div>
6 7
    <el-table :data="tableData" border stripe>
      <el-table-column label="头像" min-width="50">
8
        <template #default="scope">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
9
          <div :style="{'textAlign':'center'}">
何秀钢 已提交
10
            <CustomPic :pic-src="scope.row.headerImg" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
11
          </div>
12 13
        </template>
      </el-table-column>
何秀钢 已提交
14 15 16
      <el-table-column label="uuid" min-width="250" prop="uuid" />
      <el-table-column label="用户名" min-width="150" prop="userName" />
      <el-table-column label="昵称" min-width="150" prop="nickName" />
17
      <el-table-column label="用户角色" min-width="150">
18
        <template #default="scope">
19
          <el-cascader
20
            v-model="scope.row.authorityIds"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
21 22
            :options="authOptions"
            :show-all-levels="false"
23
            :props="{ multiple:true,checkStrictly: true,label:'authorityName',value:'authorityId',disabled:'disabled',emitPath:false}"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
24
            filterable
25 26 27
            :clearable="false"
            @visible-change="(flag)=>{changeAuthority(scope.row,flag)}"
            @remove-tag="()=>{changeAuthority(scope.row,false)}"
何秀钢 已提交
28
          />
29 30
        </template>
      </el-table-column>
31
      <el-table-column label="操作" min-width="150">
32 33
        <template #default="scope">
          <el-popover v-model:visible="scope.row.visible" placement="top" width="160">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
34 35 36 37 38
            <p>确定要删除此用户吗</p>
            <div style="text-align: right; margin: 0">
              <el-button size="mini" type="text" @click="scope.row.visible = false">取消</el-button>
              <el-button type="primary" size="mini" @click="deleteUser(scope.row)">确定</el-button>
            </div>
39 40 41
            <template #reference>
              <el-button type="danger" icon="el-icon-delete" size="mini">删除</el-button>
            </template>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
42
          </el-popover>
43 44
        </template>
      </el-table-column>
45
    </el-table>
46
    <span style="color: red;font-size: 12px">注:右上角头像下拉可切换角色</span>
47 48 49 50 51 52
    <el-pagination
      :current-page="page"
      :page-size="pageSize"
      :page-sizes="[10, 30, 50, 100]"
      :style="{float:'right',padding:'20px'}"
      :total="total"
何秀钢 已提交
53
      layout="total, sizes, prev, pager, next, jumper"
54 55
      @current-change="handleCurrentChange"
      @size-change="handleSizeChange"
何秀钢 已提交
56
    />
57

58
    <el-dialog v-model="addUserDialog" custom-class="user-dialog" title="新增用户">
何秀钢 已提交
59
      <el-form ref="userForm" :rules="rules" :model="userInfo">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
60
        <el-form-item label="用户名" label-width="80px" prop="username">
何秀钢 已提交
61
          <el-input v-model="userInfo.username" />
62
        </el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
63
        <el-form-item label="密码" label-width="80px" prop="password">
何秀钢 已提交
64
          <el-input v-model="userInfo.password" />
65
        </el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
66
        <el-form-item label="别名" label-width="80px" prop="nickName">
何秀钢 已提交
67
          <el-input v-model="userInfo.nickName" />
68 69
        </el-form-item>
        <el-form-item label="头像" label-width="80px">
70
          <div style="display:inline-block" @click="openHeaderChange">
-芈Autumn-'s avatar
-芈Autumn- 已提交
71
            <img v-if="userInfo.headerImg" class="header-img-box" :src="(userInfo.headerImg && userInfo.headerImg.slice(0, 4) !== 'http')?path+userInfo.headerImg:userInfo.headerImg">
72 73
            <div v-else class="header-img-box">从媒体库选择</div>
          </div>
74
        </el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
75
        <el-form-item label="用户角色" label-width="80px" prop="authorityId">
76
          <el-cascader
Mr.奇淼('s avatar
Mr.奇淼( 已提交
77
            v-model="userInfo.authorityIds"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
78 79
            :options="authOptions"
            :show-all-levels="false"
80
            :props="{ multiple:true,checkStrictly: true,label:'authorityName',value:'authorityId',disabled:'disabled',emitPath:false}"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
81
            filterable
82
            :clearable="false"
何秀钢 已提交
83
          />
84 85
        </el-form-item>
      </el-form>
86 87 88 89 90 91
      <template #footer>
        <div class="dialog-footer">
          <el-button @click="closeAddUserDialog">取 消</el-button>
          <el-button type="primary" @click="enterAddUserDialog">确 定</el-button>
        </div>
      </template>
92
    </el-dialog>
何秀钢 已提交
93
    <ChooseImg ref="chooseImg" :target="userInfo" :target-key="`headerImg`" />
94 95 96 97 98
  </div>
</template>

<script>
// 获取列表内容封装在mixins内部  getTableData方法 初始化已封装完成
99
const path = import.meta.env.VITE_BASE_API
Mr.奇淼('s avatar
Mr.奇淼( 已提交
100 101
import {
  getUserList,
102
  setUserAuthorities,
Mr.奇淼('s avatar
Mr.奇淼( 已提交
103 104
  register,
  deleteUser
何秀钢 已提交
105 106 107 108
} from '@/api/user'
import { getAuthorityList } from '@/api/authority'
import infoList from '@/mixins/infoList'
import { mapGetters } from 'vuex'
Mr.奇淼('s avatar
Mr.奇淼( 已提交
109 110
import CustomPic from '@/components/customPic/index.vue'
import ChooseImg from '@/components/chooseImg/index.vue'
111
export default {
何秀钢 已提交
112 113
  name: 'Api',
  components: { CustomPic, ChooseImg },
114 115 116 117
  mixins: [infoList],
  data() {
    return {
      listApi: getUserList,
Mr.奇淼('s avatar
Mr.奇淼( 已提交
118
      path: path,
119 120 121
      authOptions: [],
      addUserDialog: false,
      userInfo: {
何秀钢 已提交
122 123 124 125
        username: '',
        password: '',
        nickName: '',
        headerImg: '',
126 127
        authorityId: '',
        authorityIds: []
Mr.奇淼('s avatar
Mr.奇淼( 已提交
128 129
      },
      rules: {
Mr.奇淼('s avatar
Mr.奇淼( 已提交
130
        username: [
何秀钢 已提交
131 132
          { required: true, message: '请输入用户名', trigger: 'blur' },
          { min: 5, message: '最低5位字符', trigger: 'blur' }
Mr.奇淼('s avatar
Mr.奇淼( 已提交
133
        ],
Mr.奇淼('s avatar
Mr.奇淼( 已提交
134
        password: [
何秀钢 已提交
135 136
          { required: true, message: '请输入用户密码', trigger: 'blur' },
          { min: 6, message: '最低6位字符', trigger: 'blur' }
Mr.奇淼('s avatar
Mr.奇淼( 已提交
137 138
        ],
        nickName: [
何秀钢 已提交
139
          { required: true, message: '请输入用户昵称', trigger: 'blur' }
Mr.奇淼('s avatar
Mr.奇淼( 已提交
140 141
        ],
        authorityId: [
何秀钢 已提交
142
          { required: true, message: '请选择用户角色', trigger: 'blur' }
Mr.奇淼('s avatar
Mr.奇淼( 已提交
143
        ]
Mr.奇淼('s avatar
Mr.奇淼( 已提交
144
      }
何秀钢 已提交
145
    }
146
  },
147
  computed: {
何秀钢 已提交
148 149
    ...mapGetters('user', ['token'])
  },
150 151 152 153 154
  watch: {
    tableData() {
      this.setAuthorityIds()
    }
  },
何秀钢 已提交
155
  async created() {
156
    await this.getTableData()
何秀钢 已提交
157 158
    const res = await getAuthorityList({ page: 1, pageSize: 999 })
    this.setOptions(res.data.list)
159
  },
160
  methods: {
161 162 163 164 165
    setAuthorityIds() {
      this.tableData && this.tableData.forEach((user) => {
        const authorityIds = user.authorities && user.authorities.map(i => {
          return i.authorityId
        })
166
        user.authorityIds = authorityIds
167 168
      })
    },
何秀钢 已提交
169
    openHeaderChange() {
170 171
      this.$refs.chooseImg.open()
    },
Mr.奇淼('s avatar
Mr.奇淼( 已提交
172
    setOptions(authData) {
何秀钢 已提交
173 174
      this.authOptions = []
      this.setAuthorityOptions(authData, this.authOptions)
175
    },
Mr.奇淼('s avatar
Mr.奇淼( 已提交
176 177 178
    setAuthorityOptions(AuthorityData, optionsData) {
      AuthorityData &&
        AuthorityData.map(item => {
179
          if (item.children && item.children.length) {
Mr.奇淼('s avatar
Mr.奇淼( 已提交
180 181 182 183
            const option = {
              authorityId: item.authorityId,
              authorityName: item.authorityName,
              children: []
何秀钢 已提交
184 185 186
            }
            this.setAuthorityOptions(item.children, option.children)
            optionsData.push(option)
Mr.奇淼('s avatar
Mr.奇淼( 已提交
187 188 189 190
          } else {
            const option = {
              authorityId: item.authorityId,
              authorityName: item.authorityName
何秀钢 已提交
191 192
            }
            optionsData.push(option)
193
          }
何秀钢 已提交
194
        })
195
    },
Mr.奇淼('s avatar
Mr.奇淼( 已提交
196
    async deleteUser(row) {
何秀钢 已提交
197 198
      const res = await deleteUser({ id: row.ID })
      if (res.code === 0) {
199 200
        this.$message.success('删除成功')
        await this.getTableData()
何秀钢 已提交
201
        row.visible = false
202
      }
203
    },
204
    async enterAddUserDialog() {
205
      this.userInfo.authorityId = this.userInfo.authorityIds[0]
Mr.奇淼('s avatar
Mr.奇淼( 已提交
206 207
      this.$refs.userForm.validate(async valid => {
        if (valid) {
何秀钢 已提交
208 209 210
          const res = await register(this.userInfo)
          if (res.code === 0) {
            this.$message({ type: 'success', message: '创建成功' })
Mr.奇淼('s avatar
Mr.奇淼( 已提交
211
          }
何秀钢 已提交
212 213
          await this.getTableData()
          this.closeAddUserDialog()
Mr.奇淼('s avatar
Mr.奇淼( 已提交
214
        }
何秀钢 已提交
215
      })
216 217
    },
    closeAddUserDialog() {
何秀钢 已提交
218
      this.$refs.userForm.resetFields()
219 220
      this.userInfo.headerImg = ''
      this.userInfo.authorityIds = []
何秀钢 已提交
221
      this.addUserDialog = false
222 223
    },
    addUser() {
何秀钢 已提交
224
      this.addUserDialog = true
225
    },
226 227 228
    async changeAuthority(row, flag) {
      if (flag) {
        return
229
      }
230 231 232 233 234 235 236 237 238
      this.$nextTick(async() => {
        const res = await setUserAuthorities({
          ID: row.ID,
          authorityIds: row.authorityIds
        })
        if (res.code === 0) {
          this.$message({ type: 'success', message: '角色设置成功' })
        }
      })
239
    },
240
  }
何秀钢 已提交
241
}
242
</script>
243

何秀钢 已提交
244
<style lang="scss">
245
.user-dialog {
246 247 248 249 250 251 252 253 254
  .header-img-box {
  width: 200px;
  height: 200px;
  border: 1px dashed #ccc;
  border-radius: 20px;
  text-align: center;
  line-height: 200px;
  cursor: pointer;
}
255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273
  .avatar-uploader .el-upload:hover {
    border-color: #409eff;
  }
  .avatar-uploader-icon {
    border: 1px dashed #d9d9d9 !important;
    border-radius: 6px;
    font-size: 28px;
    color: #8c939d;
    width: 178px;
    height: 178px;
    line-height: 178px;
    text-align: center;
  }
  .avatar {
    width: 178px;
    height: 178px;
    display: block;
  }
}
何秀钢 已提交
274
</style>