yumechi-no-kuni/src/client/app/common/views/components/avatar.vue

50 lines
1.3 KiB
Vue
Raw Normal View History

2018-04-29 03:17:15 -05:00
<template>
<router-link class="mk-avatar" :to="user | userPage" :title="user | acct" :target="target" :style="style" v-if="disablePreview"></router-link>
<router-link class="mk-avatar" :to="user | userPage" :title="user | acct" :target="target" :style="style" v-else v-user-preview="user.id"></router-link>
2018-04-29 03:17:15 -05:00
</template>
<script lang="ts">
import Vue from 'vue';
export default Vue.extend({
props: {
user: {
type: Object,
2018-04-29 03:17:15 -05:00
required: true
},
target: {
required: false,
default: null
},
disablePreview: {
required: false,
default: false
}
},
computed: {
2018-05-20 03:37:30 -05:00
lightmode(): boolean {
2018-05-20 12:13:39 -05:00
return this.$store.state.device.lightmode;
2018-05-20 03:37:30 -05:00
},
style(): any {
return {
2018-05-21 21:34:40 -05:00
backgroundColor: this.lightmode
? `rgb(${ this.user.avatarColor.slice(0, 3).join(',') })`
: this.user.avatarColor && this.user.avatarColor.length == 3
? `rgb(${ this.user.avatarColor.join(',') })`
: null,
2018-05-20 03:37:30 -05:00
backgroundImage: this.lightmode ? null : `url(${ this.user.avatarUrl }?thumbnail)`,
2018-05-26 23:49:09 -05:00
borderRadius: this.$store.state.settings.circleIcons ? '100%' : null
};
}
2018-04-29 03:17:15 -05:00
}
});
</script>
<style lang="stylus" scoped>
.mk-avatar
2018-05-04 03:40:50 -05:00
display inline-block
2018-05-06 11:43:51 -05:00
vertical-align bottom
background-size cover
background-position center center
transition border-radius 1s ease
2018-04-29 03:17:15 -05:00
</style>