123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 |
- <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>
|