111 lines
3.0 KiB
Vue
111 lines
3.0 KiB
Vue
<template>
|
|
<div class="user-manage">
|
|
<el-card>
|
|
<template #header>
|
|
<div class="card-header">
|
|
<span>用户管理</span>
|
|
<el-input
|
|
v-model="keyword"
|
|
placeholder="搜索用户名/昵称/手机号"
|
|
style="width: 250px"
|
|
@keyup.enter="fetchUsers"
|
|
>
|
|
<template #append>
|
|
<el-button @click="fetchUsers">
|
|
<el-icon><Search /></el-icon>
|
|
</el-button>
|
|
</template>
|
|
</el-input>
|
|
</div>
|
|
</template>
|
|
<el-table :data="userList" stripe style="width: 100%">
|
|
<el-table-column prop="id" label="ID" width="80" />
|
|
<el-table-column prop="username" label="用户名" width="150" />
|
|
<el-table-column prop="nickname" label="昵称" width="150" />
|
|
<el-table-column prop="phone" label="手机号" width="150" />
|
|
<el-table-column prop="role" label="角色" width="100">
|
|
<template #default="{ row }">
|
|
<el-tag :type="row.role === 1 ? 'danger' : 'primary'">
|
|
{{ row.role === 1 ? '管理员' : '普通用户' }}
|
|
</el-tag>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column prop="status" label="状态" width="100">
|
|
<template #default="{ row }">
|
|
<el-switch
|
|
:model-value="row.status === 1"
|
|
@change="updateStatus(row)"
|
|
/>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column prop="create_time" label="注册时间" width="180" />
|
|
<el-table-column label="操作" width="150">
|
|
<template #default="{ row }">
|
|
<el-button type="danger" size="small" @click="handleDelete(row)">删除</el-button>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
</el-card>
|
|
</div>
|
|
</template>
|
|
|
|
<script setup>
|
|
import { ref, onMounted } from 'vue'
|
|
import { userApi } from '../../api'
|
|
import { ElMessage, ElMessageBox } from 'element-plus'
|
|
|
|
const userList = ref([])
|
|
const keyword = ref('')
|
|
|
|
const fetchUsers = async () => {
|
|
try {
|
|
const res = await userApi.getList(keyword.value)
|
|
if (res.code === 200) {
|
|
userList.value = res.data || []
|
|
}
|
|
} catch (e) {
|
|
console.error(e)
|
|
}
|
|
}
|
|
|
|
const updateStatus = async (user) => {
|
|
try {
|
|
const newStatus = user.status === 1 ? 0 : 1
|
|
await userApi.updateStatus(user.id, newStatus)
|
|
user.status = newStatus
|
|
ElMessage.success('操作成功')
|
|
} catch (e) {
|
|
console.error(e)
|
|
}
|
|
}
|
|
|
|
const handleDelete = async (user) => {
|
|
try {
|
|
await ElMessageBox.confirm('确定删除该用户吗?', '提示', { confirmButtonText: '确定', cancelButtonText: '取消', type: 'warning' })
|
|
await userApi.delete(user.id)
|
|
ElMessage.success('删除成功')
|
|
fetchUsers()
|
|
} catch (e) {
|
|
if (e !== 'cancel') {
|
|
console.error(e)
|
|
}
|
|
}
|
|
}
|
|
|
|
onMounted(() => {
|
|
fetchUsers()
|
|
})
|
|
</script>
|
|
|
|
<style scoped lang="scss">
|
|
.user-manage {
|
|
padding: 20px 0;
|
|
}
|
|
|
|
.card-header {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
}
|
|
</style>
|