| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- <template>
- <div
- class="profile-wrap"
- v-loading="getUserLoading"
- >
- <div class="uid">用户id:{{ userInfo?.id }}</div>
- <div class="avatar">
- <span class="txt">用户头像:</span>
- <Avatar
- :avatar="userInfo?.avatar"
- :size="30"
- :border="!userInfo?.avatar?.length"
- ></Avatar>
- </div>
- <div class="username">用户昵称:{{ userInfo?.username }}</div>
- <div
- class="username"
- v-if="userStore.userInfo"
- >
- 用户角色:{{ userInfo?.roles?.map((item) => item.role_name).join(',') }}
- </div>
- <br />
- <div class="pull-url">
- <span
- v-if="
- !userInfo?.live_rooms?.length &&
- userStore.userInfo?.id === userInfo?.id
- "
- class="link"
- @click="openLiveRoom"
- >
- 未开通
- </span>
- <span v-else-if="!userInfo?.live_rooms?.length">
- 该用户未开通直播间
- </span>
- <div v-else>
- <div>
- 直播间地址:
- <a
- :href="getLiveRoomPageUrl(userInfo?.live_rooms?.[0]?.id!)"
- class="link"
- target="_blank"
- >
- {{ getLiveRoomPageUrl(userInfo?.live_rooms?.[0]?.id!) }}
- </a>
- </div>
- <div>直播间名称:{{ userInfo?.live_rooms?.[0]?.name }}</div>
- <div>
- 直播间简介:{{ userInfo?.live_rooms?.[0]?.desc || '暂无简介' }}
- </div>
- <div>
- 直播间分区:{{
- userInfo.live_rooms[0]?.areas?.[0]?.name || '暂无分区'
- }}
- </div>
- </div>
- </div>
- </div>
- </template>
- <script lang="ts" setup>
- import { openToTarget } from 'billd-utils';
- import { ref, watchEffect } from 'vue';
- import { useRoute, useRouter } from 'vue-router';
- import { fetchFindUser } from '@/api/user';
- import { loginTip } from '@/hooks/use-login';
- import { routerName } from '@/router';
- import { useUserStore } from '@/store/user';
- import { LiveRoomTypeEnum } from '@/types/ILiveRoom';
- import { IUser } from '@/types/IUser';
- import { getLiveRoomPageUrl } from '@/utils';
- const userStore = useUserStore();
- const route = useRoute();
- const router = useRouter();
- const userId = ref(-1);
- const userInfo = ref<IUser>();
- const getUserLoading = ref(false);
- watchEffect(() => {
- if (route.params.id) {
- userId.value = Number(route.params.id as string);
- handleUserInfo();
- }
- });
- async function handleUserInfo() {
- try {
- getUserLoading.value = true;
- const res = await fetchFindUser(userId.value);
- if (res.code === 200) {
- userInfo.value = res.data;
- }
- } catch (error) {
- console.error(error);
- } finally {
- getUserLoading.value = false;
- }
- }
- function openLiveRoom() {
- if (!loginTip()) {
- return;
- }
- const url = router.resolve({
- name: routerName.push,
- query: { liveType: LiveRoomTypeEnum.srs },
- });
- openToTarget(url.href);
- }
- </script>
- <style lang="scss" scoped>
- .profile-wrap {
- position: relative;
- padding: 10px;
- .link {
- color: $theme-color-gold;
- text-decoration: none;
- cursor: pointer;
- }
- .avatar {
- display: flex;
- align-items: center;
- .txt {
- margin-right: 10px;
- }
- }
- .url-wrap {
- position: relative;
- margin-top: 10px;
- .cdn {
- margin-bottom: 10px;
- }
- }
- }
- </style>
|