feat:【ele】【member 会员】优化会员详情

This commit is contained in:
YunaiV
2025-10-07 20:46:52 +08:00
parent a2ed4445f2
commit 5e5ae1195e
15 changed files with 168 additions and 140 deletions

View File

@@ -0,0 +1,100 @@
<script setup lang="ts">
import type { MemberUserApi } from '#/api/member/user';
import { h } from 'vue';
import { DICT_TYPE } from '@vben/constants';
import { formatDate } from '@vben/utils';
import { ElAvatar, ElCard, ElCol, ElRow } from 'element-plus';
import { useDescription } from '#/components/description';
import { DictTag } from '#/components/dict-tag';
withDefaults(
defineProps<{ mode?: 'kefu' | 'member'; user: MemberUserApi.User }>(),
{
mode: 'member',
},
);
const [Descriptions] = useDescription({
componentProps: {
border: false,
column: 2,
direction: 'horizontal',
labelWidth: 140,
title: '',
extra: '',
},
schema: [
{
field: 'name',
label: '用户名',
},
{
field: 'nickname',
label: '昵称',
},
{
field: 'mobile',
label: '手机号',
},
{
field: 'sex',
label: '性别',
content: (data) =>
h(DictTag, {
type: DICT_TYPE.SYSTEM_USER_SEX,
value: data.sex,
}),
},
{
field: 'areaName',
label: '所在地',
},
{
field: 'registerIp',
label: '注册 IP',
},
{
field: 'birthday',
label: '生日',
content: (data) => formatDate(data.birthday)?.toString() || '-',
},
{
field: 'createTime',
label: '注册时间',
content: (data) => formatDate(data.createTime)?.toString() || '-',
},
{
field: 'loginDate',
label: '最后登录时间',
content: (data) => formatDate(data.loginDate)?.toString() || '-',
},
],
});
</script>
<template>
<ElCard>
<template #title>
<slot name="title"></slot>
</template>
<template #extra>
<slot name="extra"></slot>
</template>
<ElRow v-if="mode === 'member'" :gutter="24">
<ElCol :span="6">
<ElAvatar :size="180" shape="square" :src="user.avatar" />
</ElCol>
<ElCol :span="18">
<Descriptions :column="2" :data="user" />
</ElCol>
</ElRow>
<template v-else-if="mode === 'kefu'">
<ElAvatar :size="140" shape="square" :src="user.avatar" />
<Descriptions :column="1" :data="user" />
</template>
</ElCard>
</template>