rudeshark.net/src/client/app/common/views/components/avatar.vue

114 lines
2.7 KiB
Vue
Raw Normal View History

2018-04-29 10:17:15 +02:00
<template>
2018-09-12 18:06:18 +02:00
<span class="mk-avatar" :style="style" :class="{ cat }" :title="user | acct" v-if="disableLink && !disablePreview" v-user-preview="user.id" @click="onClick">
<span class="inner" :style="icon"></span>
2018-08-12 20:36:42 +02:00
</span>
2018-09-12 18:06:18 +02:00
<span class="mk-avatar" :style="style" :class="{ cat }" :title="user | acct" v-else-if="disableLink && disablePreview" @click="onClick">
<span class="inner" :style="icon"></span>
2018-08-12 20:36:42 +02:00
</span>
2018-09-12 18:06:18 +02:00
<router-link class="mk-avatar" :style="style" :class="{ cat }" :to="user | userPage" :title="user | acct" :target="target" v-else-if="!disableLink && !disablePreview" v-user-preview="user.id">
<span class="inner" :style="icon"></span>
2018-08-12 20:36:42 +02:00
</router-link>
2018-09-12 18:06:18 +02:00
<router-link class="mk-avatar" :style="style" :class="{ cat }" :to="user | userPage" :title="user | acct" :target="target" v-else-if="!disableLink && disablePreview">
<span class="inner" :style="icon"></span>
2018-08-12 20:36:42 +02:00
</router-link>
2018-04-29 10:17:15 +02:00
</template>
<script lang="ts">
import Vue from 'vue';
2018-04-29 10:17:15 +02:00
export default Vue.extend({
props: {
user: {
type: Object,
2018-04-29 10:17:15 +02:00
required: true
},
target: {
required: false,
default: null
},
2018-08-09 17:51:40 +02:00
disableLink: {
required: false,
default: false
},
2018-04-29 10:17:15 +02:00
disablePreview: {
required: false,
default: false
}
},
computed: {
2018-05-20 10:37:30 +02:00
lightmode(): boolean {
2018-05-20 19:13:39 +02:00
return this.$store.state.device.lightmode;
2018-05-20 10:37:30 +02:00
},
2018-08-12 20:36:42 +02:00
cat(): boolean {
return this.user.isCat && this.$store.state.settings.circleIcons;
},
style(): any {
2018-09-12 18:06:18 +02:00
return {
borderRadius: this.$store.state.settings.circleIcons ? '100%' : null
};
},
icon(): any {
return {
2018-05-22 04:34:40 +02:00
backgroundColor: this.lightmode
2018-08-13 22:24:51 +02:00
? `rgb(${this.user.avatarColor.slice(0, 3).join(',')})`
2018-05-22 04:34:40 +02:00
: this.user.avatarColor && this.user.avatarColor.length == 3
2018-08-13 22:24:51 +02:00
? `rgb(${this.user.avatarColor.join(',')})`
2018-05-22 04:34:40 +02:00
: null,
2018-08-13 22:24:51 +02:00
backgroundImage: this.lightmode ? null : `url(${this.user.avatarUrl})`,
2018-05-27 06:49:09 +02:00
borderRadius: this.$store.state.settings.circleIcons ? '100%' : null
};
}
2018-08-09 17:51:40 +02:00
},
2018-09-26 18:54:10 +02:00
mounted() {
2018-09-28 17:01:11 +02:00
if (this.user.avatarColor) {
this.$el.style.color = `rgb(${this.user.avatarColor.slice(0, 3).join(',')})`;
}
2018-09-26 18:54:10 +02:00
},
2018-08-09 17:51:40 +02:00
methods: {
onClick(e) {
this.$emit('click', e);
}
2018-04-29 10:17:15 +02:00
}
});
</script>
<style lang="stylus" scoped>
2018-09-26 18:54:10 +02:00
.mk-avatar
2018-05-04 10:40:50 +02:00
display inline-block
2018-05-06 18:43:51 +02:00
vertical-align bottom
2018-08-12 20:36:42 +02:00
2018-08-15 13:09:56 +02:00
&:not(.cat)
overflow hidden
border-radius 8px
2018-08-12 20:39:32 +02:00
&.cat::before,
&.cat::after
2018-08-12 20:36:42 +02:00
background #df548f
2018-09-26 18:54:10 +02:00
border solid 4px currentColor
2018-08-12 20:36:42 +02:00
box-sizing border-box
content ''
display inline-block
height 50%
width 50%
2018-08-12 20:39:32 +02:00
&.cat::before
2018-08-12 20:36:42 +02:00
border-radius 0 75% 75%
transform rotate(37.5deg) skew(30deg)
2018-08-12 20:39:32 +02:00
&.cat::after
2018-08-12 20:36:42 +02:00
border-radius 75% 0 75% 75%
transform rotate(-37.5deg) skew(-30deg)
.inner
background-position center center
background-size cover
bottom 0
left 0
position absolute
right 0
top 0
transition border-radius 1s ease
2018-08-12 20:42:12 +02:00
z-index 1
2018-08-13 22:24:51 +02:00
2018-04-29 10:17:15 +02:00
</style>