index.vue 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. <template>
  2. <div
  3. v-loading="loading"
  4. class="profile-wrap"
  5. >
  6. <div class="uid">用户id:{{ userInfo?.id }}</div>
  7. <div class="avatar">
  8. <span class="txt">用户头像:</span>
  9. <Avatar
  10. :avatar="userInfo?.avatar"
  11. :size="30"
  12. ></Avatar>
  13. </div>
  14. <div>用户昵称:{{ userInfo?.username }}</div>
  15. <br />
  16. <div>直播间信息:</div>
  17. <div v-if="userInfo?.live_rooms?.length">
  18. <div>
  19. 直播间地址:
  20. <a
  21. :href="getLiveRoomPageUrl(userInfo?.live_rooms?.[0].id!)"
  22. class="link"
  23. target="_blank"
  24. >
  25. {{ getLiveRoomPageUrl(userInfo?.live_rooms?.[0].id!) }}
  26. </a>
  27. </div>
  28. <div>直播间名称:{{ userInfo.live_rooms[0].name }}</div>
  29. <div>直播间简介:{{ userInfo.live_rooms[0].desc }}</div>
  30. <div>
  31. 直播间分区:{{ userInfo.live_rooms[0].areas?.[0].name || '暂无分区' }}
  32. </div>
  33. </div>
  34. <span v-else>未开通</span>
  35. </div>
  36. </template>
  37. <script lang="ts" setup>
  38. import { onMounted, ref } from 'vue';
  39. import { useRoute } from 'vue-router';
  40. import { fetchFindUser } from '@/api/user';
  41. import { IUser } from '@/interface';
  42. import { getLiveRoomPageUrl } from '@/utils';
  43. const loading = ref(false);
  44. const route = useRoute();
  45. const userInfo = ref<IUser>();
  46. async function handleUserInfo() {
  47. try {
  48. loading.value = true;
  49. const res = await fetchFindUser(Number(route.params.userId as string));
  50. if (res.code === 200) {
  51. userInfo.value = res.data;
  52. }
  53. } catch (error) {
  54. console.log(error);
  55. } finally {
  56. loading.value = false;
  57. }
  58. }
  59. onMounted(() => {
  60. handleUserInfo();
  61. });
  62. </script>
  63. <style lang="scss" scoped>
  64. .profile-wrap {
  65. position: relative;
  66. padding: 10px;
  67. .link {
  68. color: $theme-color-gold;
  69. text-decoration: none;
  70. cursor: pointer;
  71. }
  72. .avatar {
  73. display: flex;
  74. align-items: center;
  75. .txt {
  76. margin-right: 10px;
  77. }
  78. }
  79. }
  80. </style>