user.vue 8.0 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
          <div :style="{'textAlign':'center'}">
10
            <CustomPic :picSrc="scope.row.headerImg" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
11
          </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
          <el-cascader
20
            @change="changeAuthority(scope.row)"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
21 22 23 24 25 26
            v-model="scope.row.authority.authorityId"
            :options="authOptions"
            :show-all-levels="false"
            :props="{ checkStrictly: true,label:'authorityName',value:'authorityId',disabled:'disabled',emitPath:false}"
            filterable
          ></el-cascader>
27 28
        </template>
      </el-table-column>
29 30
      <el-table-column label="操作" min-width="150">
        <template slot-scope="scope">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
31 32 33 34 35 36
          <el-popover placement="top" width="160" v-model="scope.row.visible">
            <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>
LoeYueng's avatar
LoeYueng 已提交
37
            <el-button type="danger" icon="el-icon-delete" size="small" slot="reference">删除</el-button>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
38
          </el-popover>
39 40
        </template>
      </el-table-column>
41 42 43 44 45 46 47 48 49 50 51
    </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>
52 53

    <el-dialog :visible.sync="addUserDialog" custom-class="user-dialog" title="新增用户">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
54
      <el-form :rules="rules" ref="userForm" :model="userInfo">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
55
        <el-form-item label="用户名" label-width="80px" prop="username">
56 57
          <el-input v-model="userInfo.username"></el-input>
        </el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
58
        <el-form-item label="密码" label-width="80px" prop="password">
59 60
          <el-input v-model="userInfo.password"></el-input>
        </el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
61
        <el-form-item label="别名" label-width="80px" prop="nickName">
62 63 64
          <el-input v-model="userInfo.nickName"></el-input>
        </el-form-item>
        <el-form-item label="头像" label-width="80px">
65 66 67 68
          <div style="display:inline-block" @click="openHeaderChange">
            <img class="header-img-box" v-if="userInfo.headerImg" :src="userInfo.headerImg" />
            <div v-else class="header-img-box">从媒体库选择</div>
          </div>
69
        </el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
70
        <el-form-item label="用户角色" label-width="80px" prop="authorityId">
71
          <el-cascader
Mr.奇淼('s avatar
Mr.奇淼( 已提交
72 73 74 75 76 77
            v-model="userInfo.authorityId"
            :options="authOptions"
            :show-all-levels="false"
            :props="{ checkStrictly: true,label:'authorityName',value:'authorityId',disabled:'disabled',emitPath:false}"
            filterable
          ></el-cascader>
78 79 80 81 82 83 84
        </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
    <ChooseImg ref="chooseImg" :target="userInfo" :targetKey="`headerImg`"/>
86 87 88 89 90 91
  </div>
</template>


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

218 219 220 221 222 223
.button-box {
  padding: 10px 20px;
  .el-button {
    float: right;
  }
}
224 225

.user-dialog {
226 227 228 229 230 231 232 233 234
  .header-img-box {
  width: 200px;
  height: 200px;
  border: 1px dashed #ccc;
  border-radius: 20px;
  text-align: center;
  line-height: 200px;
  cursor: pointer;
}
235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253
  .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;
  }
}
254
</style>