首页建立-用户列表添加

This commit is contained in:
龚皓 2024-09-30 15:54:06 +08:00
parent 9a6753cfa1
commit 688658d1c2
2 changed files with 315 additions and 0 deletions

7
src/html/Home.vue Normal file
View File

@ -0,0 +1,7 @@
<template>
<div>
<h1>
首页
</h1>
</div>
</template>

308
src/html/UserList.vue Normal file
View File

@ -0,0 +1,308 @@
<template>
<div>
<el-card class="user-list">
<div class="header">
<el-row class="header-title" :gutter="10">
<el-col :span="24">用户管理</el-col>
</el-row>
<el-row class="header-button" :gutter="10">
<el-col :span="2">
<div>
<el-button type="primary" @click="showAddUserDialog">新增</el-button>
</div>
</el-col>
<el-col :span="2">
<!-- <div>
<el-button type="danger" @click="handleDeleteSelected">删除所选</el-button>
</div> -->
</el-col>
<el-col :span="18"></el-col>
<el-col :span="2">
<el-dropdown trigger="click">
<el-button type="default">表格列设置</el-button>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item v-for="(column, index) in columns" :key="index">
<el-checkbox v-model="column.visible">{{ column.label }}</el-checkbox>
</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
</el-col>
</el-row>
</div>
<el-row>
<el-col :span="24">
<div class="table-part">
<el-table v-loading="loading" :data="tableData"
class="user-table" border>
<el-table-column v-if="getColumnVisibility('selection')" type="selection"
min-width="55"></el-table-column>
<el-table-column v-if="getColumnVisibility('id')" prop="id" label="序号"
min-width="100"></el-table-column>
<el-table-column v-if="getColumnVisibility('username')" prop="username" label="用户名"
min-width="180"></el-table-column>
<el-table-column v-if="getColumnVisibility('email')" prop="email" label="邮箱"
min-width="200"></el-table-column>
<el-table-column v-if="getColumnVisibility('actions')" label="操作" min-width="200" align="center">
<template #default="scope">
<el-button type="text" size="small"
@click="showEditUserDialog(scope.row)">编辑</el-button>
<el-button type="text" size="small" @click="confirmDelete(scope.row)">删除</el-button>
</template>
</el-table-column>
</el-table>
</div>
</el-col>
</el-row>
</el-card>
<!-- 用户弹窗 -->
<el-dialog :title="isEdit ? '编辑用户' : '新增用户'" v-model="userDialogVisible" width="30%">
<el-form :model="newUserForm" ref="newUserFormRef" :rules="rules" label-width="80px">
<el-form-item label="用户名" prop="username">
<el-input v-model="newUserForm.username" :disabled="isEdit" />
</el-form-item>
<el-form-item label="邮箱" prop="email">
<el-input v-model="newUserForm.email" :disabled="isEdit" />
</el-form-item>
<el-form-item label="密码" prop="password">
<el-input v-model="newUserForm.password" type="password" />
</el-form-item>
</el-form>
<template #footer>
<el-button @click="userDialogVisible = false">取消</el-button>
<el-button type="primary" v-if="!isEdit" @click="handleAddUser">新增</el-button>
<el-button type="primary" v-else @click="handleEditUser">修改</el-button>
</template>
</el-dialog>
</div>
</template>
<script lang="ts" setup>
import { ref, onMounted } from 'vue';
import { ElMessage, ElMessageBox } from 'element-plus';
import { BoxApi } from '@/utils/boxApi';
//
const columns = ref([
{ label: '序号', prop: 'id', visible: true },
{ label: '用户名', prop: 'username', visible: true },
{ label: '邮箱', prop: 'email', visible: true },
{ label: '操作', prop: 'actions', visible: true },
{ label: '选择', prop: 'selection', visible: true }
]);
//
const tableData = ref([]); //
const loading = ref(false);
const selectedRows = ref<any[]>([]);
const userDialogVisible = ref(false); //
const isEdit = ref(false); //
//
const newUserForm = ref({
username: '',
email: '',
password: ''
});
const newUserFormRef = ref(); //
const rules = {
username: [{ required: true, message: '请输入用户名', trigger: 'blur' }],
email: [{ required: true, message: '请输入邮箱', trigger: 'blur' }],
password: [{ required: true, message: '请输入密码', trigger: 'blur' }]
};
// localStorage token
const token = localStorage.getItem('alertToken');
// const token = "";
// BoxApi token
let apiInstance = new BoxApi();
if (token) {
apiInstance.setToken(token); // token
} else {
console.error('Token is missing. Please login.');
}
//
const getColumnVisibility = (prop: string) => {
const column = columns.value.find((col) => col.prop === prop);
return column ? column.visible : false;
};
//
const refreshTable = async () => {
loading.value = true;
try {
const users = await apiInstance.getAllUsers(); // getAllUsers
tableData.value = users.map((user: any, index: number) => ({
id: index + 1, // id
username: user.username,
email: user.email
}));
} catch (error) {
ElMessage.error('刷新用户列表失败');
} finally {
loading.value = false;
}
};
//
onMounted(() => {
refreshTable();
});
//
const showAddUserDialog = () => {
isEdit.value = false; //
newUserForm.value = { username: '', email: '', password: '' }; //
userDialogVisible.value = true;
};
//
const showEditUserDialog = (user: any) => {
isEdit.value = true; //
newUserForm.value = { ...user, password: '' }; //
userDialogVisible.value = true;
};
//
const handleAddUser = () => {
newUserFormRef.value?.validate(async (valid: boolean) => {
if (valid) {
try {
const res = await apiInstance.addUser(newUserForm.value.username, newUserForm.value.password, newUserForm.value.email);
ElMessage.success('新增用户成功');
userDialogVisible.value = false;
refreshTable();
} catch (error: any) {
if (error && error.ec !== undefined && error.dm && error.em) {
const errMessage = `
<div> 错误代码: ${error.ec}</div>
<div> 描述: ${error.dm}</div>
<div> 信息: ${error.em}</div>
`;
ElMessage({
message: errMessage,
type: 'error',
dangerouslyUseHTMLString: true,
duration: 3000,
offset: 50
});
} else {
ElMessage.error('新增用户失败');
}
}
} else {
ElMessage.warning('表单验证失败,请检查输入');
}
});
};
// resetUser
const handleEditUser = () => {
newUserFormRef.value?.validate(async (valid: boolean) => {
if (valid) {
try {
const res = await apiInstance.resetUser(
newUserForm.value.username,
newUserForm.value.password,
newUserForm.value.email
);
ElMessage.success('用户信息修改成功');
userDialogVisible.value = false;
refreshTable();
} catch (error: any) {
ElMessage.error('修改用户信息失败');
}
}
});
};
//
const confirmDelete = (row: any) => {
ElMessageBox.confirm(`是否确认删除用户 ${row.username}?`, '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
}).then(() => {
handleDelete(row); //
}).catch(() => {
ElMessage.info('已取消删除');
});
};
//
const handleDelete = async (row: any) => {
try {
await apiInstance.rmUser(row.username); // rmUser API
ElMessage.success(`用户 ${row.username} 删除成功`);
refreshTable(); //
} catch (error) {
ElMessage.error('删除用户失败');
}
};
//
const handleDeleteSelected = () => {
if (selectedRows.value.length === 0) {
ElMessage.warning('请选择要删除的用户');
return;
}
ElMessage.success('删除成功');
};
</script>
<style scoped>
.user-list {
width: auto;
overflow: auto;
/* min-height: 650px; */
/* height: 100vh; */
max-width: 1500px;
}
.user-table{
}
.header {
display: flex;
flex-direction: column;
width: 100%;
margin-bottom: 20px;
}
.header-title {
width: 100%;
padding-left: 0px;
font-size: 24px;
font-weight: bold;
}
.header-button {
width: 100%;
display: flex;
margin-top: 20px;
}
.header-button .el-button {
width: 100px;
height: 30px;
display: flex;
justify-content: center;
}
.table-part {
overflow: auth;
width: 100%;
height: 100%;
padding-left: 1px;
/* 外边距设定值后列自动扩大问题 */
box-sizing: border-box;
}
</style>