Skip to content
Snippets Groups Projects
user_card_content.vue 6.71 KiB
Newer Older
<template>
  <div id="heading" class="profile-panel-background" :style="headingStyle">
    <div class="panel-heading text-center">
      <div class='user-info'>
eal's avatar
eal committed
        <router-link to='/user-settings' style="float: right; margin-top:16px;" v-if="!isOtherUser">
          <i class="icon-cog usersettings"></i>
        </router-link>
          <router-link :to="{ name: 'user-profile', params: { id: user.id } }">
            <StillImage class="avatar" :src="user.profile_image_url_original"/>
          </router-link>
          <span class="glyphicon glyphicon-user"></span>
          <div class="name-and-screen-name">
            <div class='user-name'>{{user.name}}</div>
            <router-link :to="{ name: 'user-profile', params: { id: user.id } }">
              <div class='user-screen-name'>@{{user.screen_name}}</div>
            </router-link>
        <div v-if="isOtherUser" class="user-interactions">
          <div v-if="user.follows_you && loggedIn" class="following">
Roger Braun's avatar
Roger Braun committed
            {{ $t('user_card.follows_you') }}
lain's avatar
lain committed
          </div>
          <div class="follow" v-if="loggedIn">
lain's avatar
lain committed
            <span v-if="user.following">
              <button @click="unfollowUser" class="pressed">
Roger Braun's avatar
Roger Braun committed
                {{ $t('user_card.following') }}
lain's avatar
lain committed
              </button>
lain's avatar
lain committed
            </span>
              <button @click="followUser">
Roger Braun's avatar
Roger Braun committed
                {{ $t('user_card.follow') }}
lain's avatar
lain committed
              </button>
            </span>
          </div>
          <div class='mute' v-if='isOtherUser'>
            <span v-if='user.muted'>
              <button @click="toggleMute" class="pressed">
Roger Braun's avatar
Roger Braun committed
                {{ $t('user_card.muted') }}
              </button>
              <button @click="toggleMute">
Roger Braun's avatar
Roger Braun committed
                {{ $t('user_card.mute') }}
              </button>
          <div class="remote-follow" v-if='!loggedIn && user.is_local'>
            <form method="POST" :action='subscribeUrl'>
              <input type="hidden" name="nickname" :value="user.screen_name">
              <input type="hidden" name="profile" value="">
              <button click="submit" class="remote-button">
                {{ $t('user_card.remote_follow') }}
              </button>
            </form>
          </div>
          <div class='block' v-if='isOtherUser && loggedIn'>
eal's avatar
eal committed
            <span v-if='user.statusnet_blocking'>
              <button @click="unblockUser" class="pressed">
eal's avatar
eal committed
                {{ $t('user_card.blocked') }}
              </button>
            </span>
            <span v-if='!user.statusnet_blocking'>
              <button @click="blockUser">
eal's avatar
eal committed
                {{ $t('user_card.block') }}
              </button>
            </span>
          </div>
lain's avatar
lain committed
        </div>
      </div>
    </div>
    <div class="panel-body profile-panel-body">
      <div class="user-counts">
        <div class="user-count">
          <a href="#" v-on:click.prevent="setProfileView('statuses')" v-if="switcher"><h5>{{ $t('user_card.statuses') }}</h5></a>
Roger Braun's avatar
Roger Braun committed
          <h5 v-else>{{ $t('user_card.statuses') }}</h5>
          <span>{{user.statuses_count}} <br><span class="dailyAvg">{{dailyAvg}} {{ $t('user_card.per_day') }}</span></span>
        </div>
        <div class="user-count">
          <a href="#" v-on:click.prevent="setProfileView('friends')" v-if="switcher"><h5>{{ $t('user_card.followees') }}</h5></a>
Roger Braun's avatar
Roger Braun committed
          <h5 v-else>{{ $t('user_card.followees') }}</h5>
          <span>{{user.friends_count}}</span>
        </div>
        <div class="user-count">
          <a href="#" v-on:click.prevent="setProfileView('followers')" v-if="switcher"><h5>{{ $t('user_card.followers') }}</h5></a>
Roger Braun's avatar
Roger Braun committed
          <h5 v-else>{{ $t('user_card.followers') }}</h5>
          <span>{{user.followers_count}}</span>
        </div>
      </div>
      <p>{{user.description}}</p>
    </div>
  </div>
</template>

<script src="./user_card_content.js"></script>
eal's avatar
eal committed
@import '../../_variables.scss';
HJ's avatar
HJ committed
  background-size: cover;
  border-radius: $fallback--panelRadius;
  border-radius: var(--panelRadius, $fallback--panelRadius);
HJ's avatar
HJ committed
  .panel-heading {
    padding: 0.6em 0em;
    text-align: center;
  }
HJ's avatar
HJ committed
  top: -0em;
  padding-top: 4em;
  word-wrap: break-word;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0), $fallback--bg 80%);
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0), var(--bg, $fallback--bg) 80%)
HJ's avatar
HJ committed
  color: white;
  padding: 0 16px 16px 16px;
  margin-bottom: -4em;
HJ's avatar
HJ committed
  .container {
    padding: 16px 10px 4px 10px;
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    align-content: flex-start;
    justify-content: center;
    max-height: 56px;
    overflow: hidden;
  }
HJ's avatar
HJ committed
  .avatar {
HJ's avatar
HJ committed
    border-radius: $fallback--avatarRadius;
    border-radius: var(--avatarRadius, $fallback--avatarRadius);
HJ's avatar
HJ committed
    flex: 1 0 100%;
    width: 56px;
    height: 56px;
    box-shadow: 0px 1px 8px rgba(0,0,0,0.75);
    object-fit: cover;
HJ's avatar
HJ committed

HJ's avatar
HJ committed
    &.animated::before {
      display: none;
HJ's avatar
HJ committed
    }
HJ's avatar
HJ committed
  }
HJ's avatar
HJ committed

HJ's avatar
HJ committed
  &:hover .animated.avatar {
    canvas {
      display: none;
    }
    img {
      visibility: visible;
HJ's avatar
HJ committed
  }
HJ's avatar
HJ committed
  text-shadow: 0px 1px 1.5px rgba(0, 0, 0, 1.0);
HJ's avatar
HJ committed
  .name-and-screen-name {
    display: block;
    margin-left: 0.6em;
    text-align: left;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
HJ's avatar
HJ committed
  .user-name{
    color: white;
  }
HJ's avatar
HJ committed
  .user-screen-name {
    color: white;
    font-weight: lighter;
    font-size: 15px;
    padding-right: 0.1em;
    flex: 0 0 auto;
  }
HJ's avatar
HJ committed
  .user-interactions {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
HJ's avatar
HJ committed
    div {
      flex: 1;
    }
    margin-top: 0.7em;
    margin-bottom: -1.0em;
HJ's avatar
HJ committed
    .following {
      color: white;
      font-size: 14px;
      flex: 0 0 100%;
      margin: -0.7em 0.0em 0.3em 0.0em;
      padding-left: 16px;
      text-align: left;
    }
HJ's avatar
HJ committed
    .mute {
      max-width: 220px;
      min-height: 28px;
    }
HJ's avatar
HJ committed
    .remote-follow {
      max-width: 220px;
      min-height: 28px;
    }
HJ's avatar
HJ committed
    .follow {
      max-width: 220px;
      min-height: 28px;
    }
HJ's avatar
HJ committed
    button {
      width: 92%;
      height: 100%;
    }
HJ's avatar
HJ committed
    .remote-button {
      height: 28px !important;
      width: 92%;
    }
HJ's avatar
HJ committed
    .pressed {
      border-bottom-color: rgba(255, 255, 255, 0.2);
      border-top-color: rgba(0, 0, 0, 0.2);
HJ's avatar
HJ committed
  }
HJ's avatar
HJ committed
  display: flex;
  line-height:16px;
  padding: 1em 1.5em 0em 1em;
  text-align: center;
HJ's avatar
HJ committed
  flex: 1;
HJ's avatar
HJ committed
  h5 {
    color: white;
    font-size:1em;
    font-weight: bolder;
    margin: 0 0 0.25em;
  }
  a {
    text-decoration: none;
  }
HJ's avatar
HJ committed
  font-size: 0.8em;
  opacity: 0.5;