user.vue 6.1 KB
Newer Older
1 2
<template>
  <div>
3 4 5
    <div class="button-box clearflex">
      <el-button @click="addUser" type="primary">新增用户</el-button>
    </div>
6 7 8
    <el-table :data="tableData" border stripe>
      <el-table-column label="头像" min-width="50">
        <template slot-scope="scope">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
9 10 11
          <div :style="{'textAlign':'center'}">
            <img :src="scope.row.headerImg" height="50" width="50" />
          </div>
12 13
        </template>
      </el-table-column>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
14
      <el-table-column label="uuid" min-width="250" prop="uuid"></el-table-column>
15 16
      <el-table-column label="用户名" min-width="150" prop="userName"></el-table-column>
      <el-table-column label="昵称" min-width="150" prop="nickName"></el-table-column>
17
      <el-table-column label="用户角色" min-width="150">
18
        <template slot-scope="scope">
19 20 21 22 23 24 25 26 27 28 29 30
          <el-select
            @change="changeAuthority(scope.row)"
            placeholder="请选择"
            v-model="scope.row.authority.authorityId"
          >
            <el-option
              :key="item.authorityId"
              :label="item.authorityName"
              :value="item.authorityId"
              v-for="item in authOptions"
            ></el-option>
          </el-select>
31 32 33 34 35 36 37 38 39 40 41 42 43
        </template>
      </el-table-column>
    </el-table>
    <el-pagination
      :current-page="page"
      :page-size="pageSize"
      :page-sizes="[10, 30, 50, 100]"
      :style="{float:'right',padding:'20px'}"
      :total="total"
      @current-change="handleCurrentChange"
      @size-change="handleSizeChange"
      layout="total, sizes, prev, pager, next, jumper"
    ></el-pagination>
44 45

    <el-dialog :visible.sync="addUserDialog" custom-class="user-dialog" title="新增用户">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
46 47
      <el-form :rules="rules" ref="userForm" :model="userInfo" >
        <el-form-item label="用户名" label-width="80px" prop="username">
48 49
          <el-input v-model="userInfo.username"></el-input>
        </el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
50
        <el-form-item label="密码" label-width="80px" prop="password">
51 52
          <el-input v-model="userInfo.password"></el-input>
        </el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
53
        <el-form-item label="别名" label-width="80px" prop="nickName">
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
          <el-input v-model="userInfo.nickName"></el-input>
        </el-form-item>
        <el-form-item label="头像" label-width="80px">
          <el-upload
            :headers="{'x-token':token}"
            :on-success="handleAvatarSuccess"
            :show-file-list="false"
            :action="`${path}/fileUploadAndDownload/upload?noSave=1`"
            class="avatar-uploader"
            name="file"
          >
            <img :src="userInfo.headerImg" class="avatar" v-if="userInfo.headerImg" />
            <i class="el-icon-plus avatar-uploader-icon" v-else></i>
          </el-upload>
        </el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
69
        <el-form-item label="用户角色" label-width="80px" prop="authorityId">
70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
          <el-select placeholder="请选择" v-model="userInfo.authorityId">
            <el-option
              :key="item.authorityId"
              :label="item.authorityName"
              :value="item.authorityId"
              v-for="item in authOptions"
            ></el-option>
          </el-select>
        </el-form-item>
      </el-form>
      <div class="dialog-footer" slot="footer">
        <el-button @click="closeAddUserDialog">取 消</el-button>
        <el-button @click="enterAddUserDialog" type="primary">确 定</el-button>
      </div>
    </el-dialog>
85 86 87 88 89 90
  </div>
</template>


<script>
// 获取列表内容封装在mixins内部  getTableData方法 初始化已封装完成
91
const path = process.env.VUE_APP_BASE_API
92
import { getUserList, setUserAuthority, register } from '@/api/user'
93
import { getAuthorityList } from '@/api/authority'
94
import infoList from '@/components/mixins/infoList'
95
import { mapGetters } from 'vuex'
96 97 98 99 100 101
export default {
  name: 'Api',
  mixins: [infoList],
  data() {
    return {
      listApi: getUserList,
102 103 104 105 106 107 108 109 110
      path:path,
      authOptions: [],
      addUserDialog: false,
      userInfo: {
        username: '',
        password: '',
        nickName: '',
        headerImg: '',
        authorityId: ''
Mr.奇淼('s avatar
Mr.奇淼( 已提交
111 112 113 114 115 116 117 118 119 120 121 122 123
      },
      rules: {
        username: [{ required: true, message: '请输入用户名', trigger: 'blur' }],
        password: [
          { required: true, message: '请输入用户密码', trigger: 'blur' }
        ],
        nickName: [
          { required: true, message: '请输入用户昵称', trigger: 'blur' }
        ],
        authorityId: [
          { required: true, message: '请选择用户角色', trigger: 'blur' }
        ]
      },
124 125
    }
  },
126 127 128
  computed: {
    ...mapGetters('user', ['token'])
  },
129
  methods: {
130
    async enterAddUserDialog() {
Mr.奇淼('s avatar
Mr.奇淼( 已提交
131 132
      this.$refs.userForm.validate(async valid => {
        if (valid) {
133
          const res = await register(this.userInfo)
134
          if (res.code == 0) {
Mr.奇淼('s avatar
Mr.奇淼( 已提交
135 136 137 138 139 140
            this.$message({ type: 'success', message: '创建成功' })
          }
          await this.getTableData()
          this.closeAddUserDialog()
        }
      })
141 142
    },
    closeAddUserDialog() {
Mr.奇淼('s avatar
Mr.奇淼( 已提交
143
      this.$refs.userForm.resetFields()
144 145 146 147 148 149 150 151
      this.addUserDialog = false
    },
    handleAvatarSuccess(res) {
      this.userInfo.headerImg = res.data.file.url
    },
    addUser() {
      this.addUserDialog = true
    },
152 153 154 155
    async changeAuthority(row) {
      const res = await setUserAuthority({
        uuid: row.uuid,
        authorityId: row.authority.authorityId
Mr.奇淼('s avatar
Mr.奇淼( 已提交
156
      })
157
      if (res.code == 0) {
158 159
        this.$message({ type: 'success', message: '角色设置成功' })
      }
160
    }
161 162 163 164
  },
  async created() {
    const res = await getAuthorityList({ page: 1, pageSize: 999 })
    this.authOptions = res.data.list
165
  }
166 167

  
168 169 170 171 172 173 174 175 176
}
</script>
<style scoped lang="scss">
.button-box {
  padding: 10px 20px;
  .el-button {
    float: right;
  }
}
177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197

.user-dialog {
  .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;
  }
}
198
</style>