|
|
@@ -14,6 +14,7 @@
|
|
|
<el-select v-model="queryParams.status" placeholder="用户状态" clearable>
|
|
|
<el-option label="正常" :value="0" />
|
|
|
<el-option label="禁用" :value="1" />
|
|
|
+ <el-option label="管理员" :value="2" />
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
<el-form-item>
|
|
|
@@ -28,36 +29,71 @@
|
|
|
<el-card shadow="hover">
|
|
|
<template #header>
|
|
|
<el-row :gutter="10">
|
|
|
+ <el-col :span="1.5">
|
|
|
+ <el-button v-has-permi="['miniapp:user:edit']" type="success" plain icon="Edit" :disabled="single" @click="handleUpdate(selectedRow)">修改</el-button>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="1.5">
|
|
|
+ <el-button v-has-permi="['miniapp:user:remove']" type="danger" plain icon="Delete" :disabled="multiple" @click="handleBatchDelete">删除</el-button>
|
|
|
+ </el-col>
|
|
|
<el-col :span="1.5">
|
|
|
<el-button v-has-permi="['miniapp:user:export']" type="warning" plain icon="Download" @click="handleExport">导出</el-button>
|
|
|
</el-col>
|
|
|
+ <el-col :span="1.5">
|
|
|
+ <el-button type="info" plain icon="Refresh" @click="handleRefresh" :loading="refreshing">刷新</el-button>
|
|
|
+ </el-col>
|
|
|
<right-toolbar v-model:show-search="showSearch" @query-table="getList"></right-toolbar>
|
|
|
</el-row>
|
|
|
</template>
|
|
|
|
|
|
- <el-table v-loading="loading" border :data="userList">
|
|
|
- <el-table-column label="用户ID" align="center" prop="id" width="80" />
|
|
|
- <el-table-column label="头像" align="center" width="80">
|
|
|
- <template #default="scope">
|
|
|
- <el-avatar :size="40" :src="scope.row.avatar || defaultAvatar" />
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
+ <el-table v-loading="loading" border :data="userList" stripe @selection-change="handleSelectionChange">
|
|
|
+ <el-table-column type="selection" width="55" align="center" />
|
|
|
+ <el-table-column label="ID" align="center" prop="id" />
|
|
|
<el-table-column label="昵称" align="center" prop="nickname" :show-overflow-tooltip="true" />
|
|
|
- <el-table-column label="手机号" align="center" prop="phone" width="120" />
|
|
|
- <el-table-column label="状态" align="center" width="100">
|
|
|
+ <el-table-column label="手机号" align="center" prop="phone" />
|
|
|
+ <el-table-column label="状态" align="center">
|
|
|
<template #default="scope">
|
|
|
- <el-switch
|
|
|
- v-model="scope.row.status"
|
|
|
- :active-value="0"
|
|
|
- :inactive-value="1"
|
|
|
- @change="handleStatusChange(scope.row)"
|
|
|
- />
|
|
|
+ <el-tag v-if="scope.row.status === 2" type="warning" size="small">管理员</el-tag>
|
|
|
+ <el-tag v-else-if="scope.row.status === 0" type="success" size="small">正常</el-tag>
|
|
|
+ <el-tag v-else type="danger" size="small">禁用</el-tag>
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
- <el-table-column label="注册时间" align="center" prop="createTime" width="180" />
|
|
|
- <el-table-column label="操作" align="center" width="150">
|
|
|
+ <el-table-column label="注册时间" align="center" prop="createTime" />
|
|
|
+ <el-table-column label="操作" align="center" width="280">
|
|
|
<template #default="scope">
|
|
|
- <el-button v-has-permi="['miniapp:user:query']" link type="primary" icon="View" @click="handleView(scope.row)">详情</el-button>
|
|
|
+ <el-tooltip content="修改" placement="top">
|
|
|
+ <el-button v-has-permi="['miniapp:user:edit']" link type="primary" icon="Edit" @click="handleUpdate(scope.row)"></el-button>
|
|
|
+ </el-tooltip>
|
|
|
+ <el-tooltip content="删除" placement="top">
|
|
|
+ <el-button v-has-permi="['miniapp:user:remove']" link type="danger" icon="Delete" @click="handleDelete(scope.row)"></el-button>
|
|
|
+ </el-tooltip>
|
|
|
+ <el-button
|
|
|
+ v-if="scope.row.status === 0"
|
|
|
+ v-has-permi="['miniapp:user:edit']"
|
|
|
+ link
|
|
|
+ type="danger"
|
|
|
+ @click="handleDisable(scope.row)"
|
|
|
+ >禁用</el-button>
|
|
|
+ <el-button
|
|
|
+ v-if="scope.row.status === 1"
|
|
|
+ v-has-permi="['miniapp:user:edit']"
|
|
|
+ link
|
|
|
+ type="success"
|
|
|
+ @click="handleEnable(scope.row)"
|
|
|
+ >启用</el-button>
|
|
|
+ <el-button
|
|
|
+ v-if="scope.row.status === 0"
|
|
|
+ v-has-permi="['miniapp:user:edit']"
|
|
|
+ link
|
|
|
+ type="warning"
|
|
|
+ @click="handleSetAdmin(scope.row)"
|
|
|
+ >设为管理员</el-button>
|
|
|
+ <el-button
|
|
|
+ v-if="scope.row.status === 2"
|
|
|
+ v-has-permi="['miniapp:user:edit']"
|
|
|
+ link
|
|
|
+ type="info"
|
|
|
+ @click="handleCancelAdmin(scope.row)"
|
|
|
+ >取消管理员</el-button>
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
</el-table>
|
|
|
@@ -79,29 +115,57 @@
|
|
|
<el-descriptions-item label="手机号">{{ currentUser.phone }}</el-descriptions-item>
|
|
|
<el-descriptions-item label="OpenID">{{ currentUser.openid }}</el-descriptions-item>
|
|
|
<el-descriptions-item label="状态">
|
|
|
- <el-tag :type="currentUser.status === 0 ? 'success' : 'danger'">
|
|
|
- {{ currentUser.status === 0 ? '正常' : '禁用' }}
|
|
|
+ <el-tag :type="currentUser.status === 0 ? 'success' : (currentUser.status === 2 ? 'warning' : 'danger')">
|
|
|
+ {{ currentUser.status === 0 ? '正常' : (currentUser.status === 2 ? '管理员' : '禁用') }}
|
|
|
</el-tag>
|
|
|
</el-descriptions-item>
|
|
|
<el-descriptions-item label="注册时间">{{ currentUser.createTime }}</el-descriptions-item>
|
|
|
</el-descriptions>
|
|
|
</el-dialog>
|
|
|
+
|
|
|
+ <!-- 修改对话框 -->
|
|
|
+ <el-dialog v-model="formDialog.visible" title="修改用户" width="500px" append-to-body>
|
|
|
+ <el-form ref="formRef" :model="form" :rules="rules" label-width="80px">
|
|
|
+ <el-form-item label="昵称" prop="nickname">
|
|
|
+ <el-input v-model="form.nickname" placeholder="请输入昵称" />
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item label="手机号" prop="phone">
|
|
|
+ <el-input v-model="form.phone" placeholder="请输入手机号" maxlength="11" />
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item label="状态" prop="status">
|
|
|
+ <el-select v-model="form.status" placeholder="请选择状态">
|
|
|
+ <el-option label="正常" :value="0" />
|
|
|
+ <el-option label="禁用" :value="1" />
|
|
|
+ <el-option label="管理员" :value="2" />
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ </el-form>
|
|
|
+ <template #footer>
|
|
|
+ <el-button @click="formDialog.visible = false">取消</el-button>
|
|
|
+ <el-button type="primary" @click="submitForm">确定</el-button>
|
|
|
+ </template>
|
|
|
+ </el-dialog>
|
|
|
</div>
|
|
|
</template>
|
|
|
|
|
|
<script setup name="MiniappUser" lang="ts">
|
|
|
-import { ref, onMounted, getCurrentInstance } from 'vue';
|
|
|
-import { listMiniappUser, getMiniappUser, changeUserStatus } from '@/api/miniapp/user';
|
|
|
+import { ref, onMounted, getCurrentInstance, reactive } from 'vue';
|
|
|
+import { listMiniappUser, getMiniappUser, updateMiniappUser, delMiniappUser, changeUserStatus } from '@/api/miniapp/user';
|
|
|
|
|
|
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
|
|
|
|
|
|
-const defaultAvatar = 'https://cube.elemecdn.com/3/7c/3ea6beec64369c2642b92c6726f1epng.png';
|
|
|
const userList = ref<any[]>([]);
|
|
|
const loading = ref(true);
|
|
|
+const refreshing = ref(false);
|
|
|
const showSearch = ref(true);
|
|
|
const total = ref(0);
|
|
|
+const ids = ref<number[]>([]);
|
|
|
+const single = ref(true);
|
|
|
+const multiple = ref(true);
|
|
|
+const selectedRow = ref<any>({});
|
|
|
|
|
|
const queryFormRef = ref<ElFormInstance>();
|
|
|
+const formRef = ref<ElFormInstance>();
|
|
|
|
|
|
const queryParams = ref({
|
|
|
pageNum: 1,
|
|
|
@@ -115,6 +179,27 @@ const detailDialog = ref({
|
|
|
visible: false
|
|
|
});
|
|
|
|
|
|
+const formDialog = ref({
|
|
|
+ visible: false,
|
|
|
+ title: ''
|
|
|
+});
|
|
|
+
|
|
|
+const form = ref<any>({
|
|
|
+ id: undefined,
|
|
|
+ nickname: '',
|
|
|
+ phone: '',
|
|
|
+ status: 0
|
|
|
+});
|
|
|
+
|
|
|
+const rules = reactive({
|
|
|
+ nickname: [{ required: true, message: '昵称不能为空', trigger: 'blur' }],
|
|
|
+ phone: [
|
|
|
+ { required: true, message: '手机号不能为空', trigger: 'blur' },
|
|
|
+ { pattern: /^1[3-9]\d{9}$/, message: '请输入正确的手机号', trigger: 'blur' }
|
|
|
+ ],
|
|
|
+ status: [{ required: true, message: '请选择状态', trigger: 'change' }]
|
|
|
+});
|
|
|
+
|
|
|
const currentUser = ref<any>({});
|
|
|
|
|
|
/** 查询用户列表 */
|
|
|
@@ -134,6 +219,16 @@ const getList = async () => {
|
|
|
}
|
|
|
};
|
|
|
|
|
|
+/** 手动刷新 */
|
|
|
+const handleRefresh = async () => {
|
|
|
+ refreshing.value = true;
|
|
|
+ try {
|
|
|
+ await getList();
|
|
|
+ } finally {
|
|
|
+ refreshing.value = false;
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
/** 搜索按钮操作 */
|
|
|
const handleQuery = () => {
|
|
|
queryParams.value.pageNum = 1;
|
|
|
@@ -147,6 +242,75 @@ const resetQuery = () => {
|
|
|
handleQuery();
|
|
|
};
|
|
|
|
|
|
+/** 多选框选中数据 */
|
|
|
+const handleSelectionChange = (selection: any[]) => {
|
|
|
+ ids.value = selection.map(item => item.id);
|
|
|
+ single.value = selection.length !== 1;
|
|
|
+ multiple.value = !selection.length;
|
|
|
+ if (selection.length === 1) {
|
|
|
+ selectedRow.value = selection[0];
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
+/** 批量删除 */
|
|
|
+const handleBatchDelete = async () => {
|
|
|
+ if (ids.value.length === 0) {
|
|
|
+ proxy?.$modal.msgWarning('请选择要删除的用户');
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ try {
|
|
|
+ await proxy?.$modal.confirm(`确认要删除选中的${ids.value.length}个用户吗?`);
|
|
|
+ for (const id of ids.value) {
|
|
|
+ await delMiniappUser(id);
|
|
|
+ }
|
|
|
+ proxy?.$modal.msgSuccess('删除成功');
|
|
|
+ getList();
|
|
|
+ } catch {
|
|
|
+ // 取消操作
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
+/** 重置表单 */
|
|
|
+const resetForm = () => {
|
|
|
+ form.value = {
|
|
|
+ id: undefined,
|
|
|
+ nickname: '',
|
|
|
+ phone: '',
|
|
|
+ status: 0
|
|
|
+ };
|
|
|
+ formRef.value?.resetFields();
|
|
|
+};
|
|
|
+
|
|
|
+/** 修改按钮操作 */
|
|
|
+const handleUpdate = async (row: any) => {
|
|
|
+ resetForm();
|
|
|
+ const res = await getMiniappUser(row.id);
|
|
|
+ form.value = { ...res.data };
|
|
|
+ formDialog.value.visible = true;
|
|
|
+ formDialog.value.title = '修改用户';
|
|
|
+};
|
|
|
+
|
|
|
+/** 提交表单 */
|
|
|
+const submitForm = async () => {
|
|
|
+ await formRef.value?.validate();
|
|
|
+ await updateMiniappUser(form.value);
|
|
|
+ proxy?.$modal.msgSuccess('修改成功');
|
|
|
+ formDialog.value.visible = false;
|
|
|
+ getList();
|
|
|
+};
|
|
|
+
|
|
|
+/** 删除按钮操作 */
|
|
|
+const handleDelete = async (row: any) => {
|
|
|
+ try {
|
|
|
+ await proxy?.$modal.confirm(`确认要删除用户"${row.nickname}"吗?`);
|
|
|
+ await delMiniappUser(row.id);
|
|
|
+ proxy?.$modal.msgSuccess('删除成功');
|
|
|
+ getList();
|
|
|
+ } catch {
|
|
|
+ // 取消操作
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
/** 用户状态修改 */
|
|
|
const handleStatusChange = async (row: any) => {
|
|
|
const text = row.status === 0 ? '启用' : '禁用';
|
|
|
@@ -159,6 +323,68 @@ const handleStatusChange = async (row: any) => {
|
|
|
}
|
|
|
};
|
|
|
|
|
|
+/** 切换用户状态(启用/禁用) */
|
|
|
+const handleToggleStatus = async (row: any) => {
|
|
|
+ const newStatus = row.status === 0 ? 1 : 0;
|
|
|
+ const text = newStatus === 0 ? '启用' : '禁用';
|
|
|
+ try {
|
|
|
+ await proxy?.$modal.confirm(`确认要${text}用户"${row.nickname}"吗?`);
|
|
|
+ await changeUserStatus(row.id, newStatus);
|
|
|
+ proxy?.$modal.msgSuccess(`${text}成功`);
|
|
|
+ getList();
|
|
|
+ } catch {
|
|
|
+ // 取消操作
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
+/** 设为管理员 */
|
|
|
+const handleSetAdmin = async (row: any) => {
|
|
|
+ try {
|
|
|
+ await proxy?.$modal.confirm(`确认要将用户"${row.nickname}"设为管理员吗?`);
|
|
|
+ await changeUserStatus(row.id, 2);
|
|
|
+ proxy?.$modal.msgSuccess('设置成功');
|
|
|
+ getList();
|
|
|
+ } catch {
|
|
|
+ // 取消操作
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
+/** 取消管理员 */
|
|
|
+const handleCancelAdmin = async (row: any) => {
|
|
|
+ try {
|
|
|
+ await proxy?.$modal.confirm(`确认要取消用户"${row.nickname}"的管理员权限吗?`);
|
|
|
+ await changeUserStatus(row.id, 0);
|
|
|
+ proxy?.$modal.msgSuccess('取消成功');
|
|
|
+ getList();
|
|
|
+ } catch {
|
|
|
+ // 取消操作
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
+/** 禁用用户 */
|
|
|
+const handleDisable = async (row: any) => {
|
|
|
+ try {
|
|
|
+ await proxy?.$modal.confirm(`确认要禁用用户"${row.nickname}"吗?禁用后该用户将无法使用小程序。`);
|
|
|
+ await changeUserStatus(row.id, 1);
|
|
|
+ proxy?.$modal.msgSuccess('禁用成功');
|
|
|
+ getList();
|
|
|
+ } catch {
|
|
|
+ // 取消操作
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
+/** 启用用户 */
|
|
|
+const handleEnable = async (row: any) => {
|
|
|
+ try {
|
|
|
+ await proxy?.$modal.confirm(`确认要启用用户"${row.nickname}"吗?`);
|
|
|
+ await changeUserStatus(row.id, 0);
|
|
|
+ proxy?.$modal.msgSuccess('启用成功');
|
|
|
+ getList();
|
|
|
+ } catch {
|
|
|
+ // 取消操作
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
/** 查看详情 */
|
|
|
const handleView = async (row: any) => {
|
|
|
const res = await getMiniappUser(row.id);
|