|
@@ -1,159 +0,0 @@
|
|
|
-<template>
|
|
|
- <el-dialog :title="titleMap[mode]" v-model="visible" :width="500" destroy-on-close @closed="$emit('closed')">
|
|
|
- <el-form :model="form" :rules="rules" :disabled="mode=='show'" ref="dialogForm" label-width="100px"
|
|
|
- label-position="left">
|
|
|
- <!-- <el-form-item label="头像" prop="avatar">-->
|
|
|
- <!-- <sc-upload v-model="form.avatar" title="上传头像"></sc-upload>-->
|
|
|
- <!-- </el-form-item>-->
|
|
|
- <el-form-item label="登录账号" prop="username">
|
|
|
- <el-input v-model="form.username" placeholder="用于登录系统" clearable></el-input>
|
|
|
- </el-form-item>
|
|
|
- <template v-if="mode=='add'">
|
|
|
- <el-form-item label="登录密码" prop="password">
|
|
|
- <el-input type="password" v-model="form.password" clearable show-password></el-input>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="确认密码" prop="password2">
|
|
|
- <el-input type="password" v-model="form.password2" clearable show-password></el-input>
|
|
|
- </el-form-item>
|
|
|
- </template>
|
|
|
- <el-form-item label="昵称" prop="nickName">
|
|
|
- <el-input v-model="form.nickName" placeholder="用于登录系统" clearable></el-input>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="姓名" prop="realName">
|
|
|
- <el-input v-model="form.realName" placeholder="请输入完整的真实姓名" clearable></el-input>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="性别" prop="sex">
|
|
|
- <el-radio-group v-model="form.sex">
|
|
|
- <el-radio label="男">男</el-radio>
|
|
|
- <el-radio label="女">女</el-radio>
|
|
|
- </el-radio-group>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="状态" prop="status">
|
|
|
- <el-switch v-model="form.status" :active-value="1" :inactive-value="0"></el-switch>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="所属角色" prop="roleIds">
|
|
|
- <el-select v-model="form.roleIds" placeholder="请选择分配角色" multiple clearable style="width: 100%;">
|
|
|
- <el-option v-for="item in roles" :key="item.id" :label="item.name" :value="item.id">
|
|
|
- <span style="float: left">{{ item.name }}</span>
|
|
|
- <span
|
|
|
- style="float: right;color: var(--el-text-color-secondary); font-size: 13px;">{{ item.alias }}</span>
|
|
|
- </el-option>
|
|
|
- </el-select>
|
|
|
- </el-form-item>
|
|
|
- </el-form>
|
|
|
- <template #footer>
|
|
|
- <el-button @click="visible=false">取 消</el-button>
|
|
|
- <el-button v-if="mode!='show'" type="primary" :loading="isSaveing" @click="submit()">保 存</el-button>
|
|
|
- </template>
|
|
|
- </el-dialog>
|
|
|
-</template>
|
|
|
-
|
|
|
-<script>
|
|
|
-export default {
|
|
|
- emits: ['success', 'closed'],
|
|
|
- data() {
|
|
|
- return {
|
|
|
- mode: "add",
|
|
|
- titleMap: {
|
|
|
- add: '新增用户',
|
|
|
- edit: '编辑用户',
|
|
|
- show: '查看'
|
|
|
- },
|
|
|
- visible: false,
|
|
|
- isSaveing: false,
|
|
|
- //表单数据
|
|
|
- form: {
|
|
|
- id: "",
|
|
|
- username: "",
|
|
|
- password: "",
|
|
|
- nickName: "",
|
|
|
- avatar: "",
|
|
|
- realName: "",
|
|
|
- group: "",
|
|
|
- sex: "男",
|
|
|
- status: 1,
|
|
|
- roleIds: []
|
|
|
- },
|
|
|
- //验证规则
|
|
|
- rules: {
|
|
|
- avatar: [
|
|
|
- {required: true, message: '请上传头像'}
|
|
|
- ],
|
|
|
- username: [
|
|
|
- {required: true, message: '请输入登录账号'}
|
|
|
- ],
|
|
|
- password: [
|
|
|
- {required: true, message: '请输入登录密码'},
|
|
|
- {
|
|
|
- validator: (rule, value, callback) => {
|
|
|
- if (this.form.password2 !== '') {
|
|
|
- this.$refs.dialogForm.validateField('password2');
|
|
|
- }
|
|
|
- callback();
|
|
|
- }
|
|
|
- }
|
|
|
- ],
|
|
|
- password2: [
|
|
|
- {required: true, message: '请再次输入密码'},
|
|
|
- {
|
|
|
- validator: (rule, value, callback) => {
|
|
|
- if (value !== this.form.password) {
|
|
|
- callback(new Error('两次输入密码不一致!'));
|
|
|
- } else {
|
|
|
- callback();
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- ],
|
|
|
- group: [
|
|
|
- {required: true, message: '请选择所属角色'}
|
|
|
- ]
|
|
|
- },
|
|
|
- //所需数据选项
|
|
|
- roles: []
|
|
|
- }
|
|
|
- },
|
|
|
- mounted() {
|
|
|
- this.loadRoles()
|
|
|
- },
|
|
|
- methods: {
|
|
|
- open(mode = 'add') {
|
|
|
- this.mode = mode;
|
|
|
- this.visible = true;
|
|
|
- return this
|
|
|
- },
|
|
|
- async loadRoles() {
|
|
|
- let res = await this.$API.role.listAll();
|
|
|
- this.roles = res.data;
|
|
|
- },
|
|
|
- //表单提交方法
|
|
|
- submit() {
|
|
|
- this.$refs.dialogForm.validate(async (valid) => {
|
|
|
- if (valid) {
|
|
|
- this.isSaveing = true;
|
|
|
- var res = await this.$API.user.save(this.form);
|
|
|
- this.isSaveing = false;
|
|
|
- if (res.code == 200) {
|
|
|
- this.$emit('success', this.form, this.mode)
|
|
|
- this.visible = false;
|
|
|
- this.$message.success("操作成功")
|
|
|
- } else {
|
|
|
- this.$alert(res.message, "提示", {type: 'error'})
|
|
|
- }
|
|
|
- } else {
|
|
|
- return false;
|
|
|
- }
|
|
|
- })
|
|
|
- },
|
|
|
- //表单注入数据
|
|
|
- async setData(data) {
|
|
|
- this.form = data
|
|
|
- let res = await this.$API.user.roleIds(data.id);
|
|
|
- this.form.roleIds = res.data;
|
|
|
- }
|
|
|
- }
|
|
|
-}
|
|
|
-</script>
|
|
|
-
|
|
|
-<style>
|
|
|
-</style>
|