mirror of
https://gitee.com/chu1204505056/vue-admin-beautiful.git
synced 2025-04-05 19:41:43 +08:00
96 lines
2.7 KiB
Vue
96 lines
2.7 KiB
Vue
<template>
|
|
<el-dialog
|
|
:title="title"
|
|
:visible.sync="dialogFormVisible"
|
|
width="500px"
|
|
@close="close"
|
|
>
|
|
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
|
|
<el-form-item label="用户名" prop="username">
|
|
<el-input v-model.trim="form.username" autocomplete="off"></el-input>
|
|
</el-form-item>
|
|
<el-form-item label="密码" prop="password">
|
|
<el-input
|
|
v-model.trim="form.password"
|
|
type="password"
|
|
autocomplete="off"
|
|
></el-input>
|
|
</el-form-item>
|
|
<el-form-item label="邮箱" prop="email">
|
|
<el-input v-model.trim="form.email" autocomplete="off"></el-input>
|
|
</el-form-item>
|
|
<el-form-item label="权限" prop="permissions">
|
|
<el-checkbox-group v-model="form.permissions">
|
|
<el-checkbox label="admin"></el-checkbox>
|
|
<el-checkbox label="editor"></el-checkbox>
|
|
</el-checkbox-group>
|
|
</el-form-item>
|
|
</el-form>
|
|
<div slot="footer" class="dialog-footer">
|
|
<el-button @click="close">取 消</el-button>
|
|
<el-button type="primary" @click="save">确 定</el-button>
|
|
</div>
|
|
</el-dialog>
|
|
</template>
|
|
|
|
<script>
|
|
import { doEdit } from "@/api/userManagement";
|
|
|
|
export default {
|
|
name: "UserManagementEdit",
|
|
data() {
|
|
return {
|
|
form: {
|
|
username: "",
|
|
password: "",
|
|
email: "",
|
|
permissions: [],
|
|
},
|
|
rules: {
|
|
username: [
|
|
{ required: true, trigger: "blur", message: "请输入用户名" },
|
|
],
|
|
password: [
|
|
{ required: true, trigger: "blur", message: "请输入密码" },
|
|
],
|
|
email: [{ required: true, trigger: "blur", message: "请输入邮箱" }],
|
|
permissions: [
|
|
{ required: true, trigger: "blur", message: "请选择权限" },
|
|
],
|
|
},
|
|
title: "",
|
|
dialogFormVisible: false,
|
|
};
|
|
},
|
|
created() {},
|
|
methods: {
|
|
showEdit(row) {
|
|
if (!row) {
|
|
this.title = "添加";
|
|
} else {
|
|
this.title = "编辑";
|
|
this.form = Object.assign({}, row);
|
|
}
|
|
this.dialogFormVisible = true;
|
|
},
|
|
close() {
|
|
this.$refs["form"].resetFields();
|
|
this.form = this.$options.data().form;
|
|
this.dialogFormVisible = false;
|
|
},
|
|
save() {
|
|
this.$refs["form"].validate(async (valid) => {
|
|
if (valid) {
|
|
const { msg } = await doEdit(this.form);
|
|
this.$baseMessage(msg, "success");
|
|
this.$emit("fetchData");
|
|
this.close();
|
|
} else {
|
|
return false;
|
|
}
|
|
});
|
|
},
|
|
},
|
|
};
|
|
</script>
|