admin-vue3/src/views/im/manager/group/GroupDetail.vue

126 lines
4.7 KiB
Vue

<template>
<el-drawer v-model="drawerVisible" title="群详情" size="900px" :destroy-on-close="true">
<!-- 群基本信息 -->
<el-descriptions :column="2" border>
<el-descriptions-item label="群编号">{{ detail.id }}</el-descriptions-item>
<el-descriptions-item label="群名称">{{ detail.name }}</el-descriptions-item>
<el-descriptions-item label="头像">
<el-avatar :src="detail.avatar" :size="36">
{{ detail.name?.charAt(0) ?? '?' }}
</el-avatar>
</el-descriptions-item>
<el-descriptions-item label="群主">
{{ detail.ownerNickname || '-' }} ({{ detail.ownerUserId }})
</el-descriptions-item>
<el-descriptions-item label="成员数">{{ detail.memberCount ?? 0 }}</el-descriptions-item>
<el-descriptions-item label="群状态">
<dict-tag :type="DICT_TYPE.IM_GROUP_STATUS" :value="detail.status" />
</el-descriptions-item>
<el-descriptions-item label="封禁状态" :span="2">
<dict-tag :type="DICT_TYPE.INFRA_BOOLEAN_STRING" :value="detail.banned" />
<span v-if="detail.banned" class="ml-5px text-gray-400">{{ detail.bannedReason }}</span>
</el-descriptions-item>
<el-descriptions-item label="群公告" :span="2">{{ detail.notice || '-' }}</el-descriptions-item>
<el-descriptions-item label="创建时间" :span="2">
{{ formatDate(detail.createTime) }}
</el-descriptions-item>
</el-descriptions>
<!-- 群成员列表 -->
<div class="mt-20px mb-15px flex items-center justify-between">
<span class="font-bold">群成员</span>
<el-checkbox v-model="activeOnly">仅展示当前群内的成员</el-checkbox>
</div>
<el-table v-loading="loading" :data="filteredMembers" border>
<el-table-column label="头像" width="80" align="center">
<template #default="{ row }">
<el-avatar :src="row.avatar" :size="40">
{{ row.nickname?.charAt(0) ?? '?' }}
</el-avatar>
</template>
</el-table-column>
<el-table-column label="用户编号" prop="userId" width="100" align="center" />
<el-table-column label="昵称" prop="nickname" min-width="120" show-overflow-tooltip />
<el-table-column
label="组内显示名"
prop="displayUserName"
min-width="120"
show-overflow-tooltip
>
<template #default="{ row }">{{ row.displayUserName || '-' }}</template>
</el-table-column>
<el-table-column
label="群显示备注"
prop="displayGroupName"
min-width="120"
show-overflow-tooltip
>
<template #default="{ row }">{{ row.displayGroupName || '-' }}</template>
</el-table-column>
<el-table-column label="免打扰" prop="muted" width="80" align="center">
<template #default="{ row }">
<dict-tag :type="DICT_TYPE.INFRA_BOOLEAN_STRING" :value="row.muted" />
</template>
</el-table-column>
<el-table-column label="状态" prop="status" width="100" align="center">
<template #default="{ row }">
<dict-tag :type="DICT_TYPE.COMMON_STATUS" :value="row.status" />
</template>
</el-table-column>
<el-table-column
label="入群时间"
prop="joinTime"
width="170"
align="center"
:formatter="dateFormatter"
/>
<el-table-column
label="退群时间"
prop="quitTime"
width="170"
align="center"
:formatter="dateFormatter"
/>
</el-table>
</el-drawer>
</template>
<script lang="ts" setup>
import { dateFormatter, formatDate } from '@/utils/formatTime'
import { DICT_TYPE } from '@/utils/dict'
import { CommonStatusEnum } from '@/utils/constants'
import * as ManagerGroupApi from '@/api/im/manager/group'
defineOptions({ name: 'ImGroupDetail' })
const drawerVisible = ref(false) // 抽屉的显示
const detail = ref<ManagerGroupApi.ImManagerGroupVO>(
{} as ManagerGroupApi.ImManagerGroupVO
) // 群详情数据
const loading = ref(false) // 成员列表的加载中
const memberList = ref<ManagerGroupApi.ImManagerGroupMemberVO[]>([]) // 群成员列表(含已退群)
const activeOnly = ref(true) // 仅展示当前群内的成员
/** 当前展示的群成员(按 activeOnly 前端过滤) */
const filteredMembers = computed(() =>
activeOnly.value
? memberList.value.filter((m) => m.status === CommonStatusEnum.ENABLE)
: memberList.value
)
/** 打开详情,加载群成员 */
const open = async (row: ManagerGroupApi.ImManagerGroupVO) => {
detail.value = row
drawerVisible.value = true
activeOnly.value = true
loading.value = true
try {
memberList.value = await ManagerGroupApi.getManagerGroupMemberList(row.id)
} finally {
loading.value = false
}
}
defineExpose({ open })
</script>