aboutsummaryrefslogtreecommitdiff
path: root/src/components/user_profile/user_profile.vue
blob: 36d75b9e852ea84f14fba220b34be676b00bfeb1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
<template>
<div>
  <div v-if="user" class="user-profile panel panel-default">
    <UserCard :user="user" :switcher="true" :selected="timeline.viewing" rounded="top"/>
    <tab-switcher :renderOnlyFocused="true" ref="tabSwitcher">
      <div :label="$t('user_card.statuses')" :disabled="!user.statuses_count">
        <div class="timeline">
          <template v-for="statusId in user.pinnedStatuseIds">
            <Conversation
              v-if="timeline.statusesObject[statusId]"
              class="status-fadein"
              :key="statusId"
              :statusoid="timeline.statusesObject[statusId]"
              :collapsable="true"
            />
          </template>
        </div>
        <Timeline
          :count="user.statuses_count"
          :embedded="true"
          :title="$t('user_profile.timeline_title')"
          :timeline="timeline"
          :timeline-name="'user'"
          :user-id="userId"
        />
      </div>
      <div :label="$t('user_card.followees')" v-if="followsTabVisible" :disabled="!user.friends_count">
        <FriendList :userId="userId">
          <template slot="item" slot-scope="{item}">
            <FollowCard :user="item" />
          </template>
        </FriendList>
      </div>
      <div :label="$t('user_card.followers')" v-if="followersTabVisible" :disabled="!user.followers_count">
        <FollowerList :userId="userId">
          <template slot="item" slot-scope="{item}">
            <FollowCard :user="item" :noFollowsYou="isUs" />
          </template>
        </FollowerList>
      </div>
      <Timeline
        :label="$t('user_card.media')"
        :disabled="!media.visibleStatuses.length"
        :embedded="true" :title="$t('user_card.media')"
        timeline-name="media"
        :timeline="media"
        :user-id="userId"
      />
      <Timeline
        v-if="isUs"
        :label="$t('user_card.favorites')"
        :disabled="!favorites.visibleStatuses.length"
        :embedded="true"
        :title="$t('user_card.favorites')"
        timeline-name="favorites"
        :timeline="favorites"
      />
    </tab-switcher>
  </div>
  <div v-else class="panel user-profile-placeholder">
    <div class="panel-heading">
      <div class="title">
        {{ $t('settings.profile_tab') }}
      </div>
    </div>
    <div class="panel-body">
      <span v-if="error">{{ error }}</span>
      <i class="icon-spin3 animate-spin" v-else></i>
    </div>
  </div>
</div>
</template>

<script src="./user_profile.js"></script>

<style lang="scss">

.user-profile {
  flex: 2;
  flex-basis: 500px;

  .userlist-placeholder {
    display: flex;
    justify-content: center;
    align-items: middle;
    padding: 2em;
  }

  .timeline-heading {
    display: flex;
    justify-content: center;

    .loadmore-button, .alert {
      flex: 1;
    }

    .loadmore-button {
      height: 28px;
      margin: 10px .6em;
    }

    .title, .loadmore-text {
      display: none
    }
  }
}
.user-profile-placeholder {
  .panel-body {
    display: flex;
    justify-content: center;
    align-items: middle;
    padding: 7em;
  }
}
</style>