aboutsummaryrefslogtreecommitdiff
path: root/src/components/basic_user_card/basic_user_card.vue
diff options
context:
space:
mode:
authorShpuld Shpludson <shp@cock.li>2019-02-22 14:54:12 +0000
committerShpuld Shpludson <shp@cock.li>2019-02-22 14:54:12 +0000
commite34e1ccdae06302ee734414267a357ff5b7c888c (patch)
treef1882a022a155a10ad10a3bb92d75f6a4a1f7f5a /src/components/basic_user_card/basic_user_card.vue
parent3768a4623fc227614b0b3920c2cb92ca16404a69 (diff)
parent22851a3a967cc5364a95c71bda48eccc3808bf41 (diff)
Merge branch '227-manage-blocks-mutes' into 'develop'
Add Blocks / Mutes management tabs under user settings page See merge request pleroma/pleroma-fe!578
Diffstat (limited to 'src/components/basic_user_card/basic_user_card.vue')
-rw-r--r--src/components/basic_user_card/basic_user_card.vue92
1 files changed, 92 insertions, 0 deletions
diff --git a/src/components/basic_user_card/basic_user_card.vue b/src/components/basic_user_card/basic_user_card.vue
new file mode 100644
index 00000000..4ede15e9
--- /dev/null
+++ b/src/components/basic_user_card/basic_user_card.vue
@@ -0,0 +1,92 @@
+<template>
+ <div class="user-card">
+ <router-link :to="userProfileLink(user)">
+ <UserAvatar class="avatar" :compact="true" @click.prevent.native="toggleUserExpanded" :src="user.profile_image_url"/>
+ </router-link>
+ <div class="user-card-expanded-content" v-if="userExpanded">
+ <user-card-content :user="user" :switcher="false"></user-card-content>
+ </div>
+ <div class="user-card-collapsed-content" v-else>
+ <div class="user-card-primary-area">
+ <div :title="user.name" class="user-name">
+ <span v-if="user.name_html" v-html="user.name_html"></span>
+ <span v-else>{{ user.name }}</span>
+ </div>
+ <div>
+ <router-link class='user-screen-name' :to="userProfileLink(user)">
+ @{{user.screen_name}}
+ </router-link>
+ </div>
+ </div>
+ <div class="user-card-secondary-area">
+ <slot name="secondary-area"></slot>
+ </div>
+ </div>
+ </div>
+</template>
+
+<script src="./basic_user_card.js"></script>
+
+<style lang="scss">
+@import '../../_variables.scss';
+
+.user-card {
+ display: flex;
+ flex: 1 0;
+ padding-top: 0.6em;
+ padding-right: 1em;
+ padding-bottom: 0.6em;
+ padding-left: 1em;
+ border-bottom: 1px solid;
+ margin: 0;
+ border-bottom-color: $fallback--border;
+ border-bottom-color: var(--border, $fallback--border);
+
+ &-collapsed-content {
+ margin-left: 0.7em;
+ text-align: left;
+ flex: 1;
+ display: flex;
+ align-items: flex-start;
+ justify-content: space-between;
+ }
+
+ &-primary-area {
+ flex: 1;
+ .user-name {
+ img {
+ object-fit: contain;
+ height: 16px;
+ width: 16px;
+ vertical-align: middle;
+ }
+ }
+ }
+
+ &-secondary-area {
+ flex: none;
+ }
+
+ &-expanded-content {
+ flex: 1;
+ margin: 0.2em 0 0 0.7em;
+ border-radius: $fallback--panelRadius;
+ border-radius: var(--panelRadius, $fallback--panelRadius);
+ border-style: solid;
+ border-color: $fallback--border;
+ border-color: var(--border, $fallback--border);
+ border-width: 1px;
+ overflow: hidden;
+
+ .panel-heading {
+ background: transparent;
+ flex-direction: column;
+ align-items: stretch;
+ }
+
+ p {
+ margin-bottom: 0;
+ }
+ }
+}
+</style>