95 lines
1.5 KiB
Vue
95 lines
1.5 KiB
Vue
<template>
|
|
<div class="mk-user-preview">
|
|
<mk-avatar class="avatar" :user="user"/>
|
|
<div class="main">
|
|
<header>
|
|
<router-link class="name" :to="user | userPage">{{ user | userName }}</router-link>
|
|
<span class="username">@{{ user | acct }}</span>
|
|
</header>
|
|
<div class="body">
|
|
<div class="description">{{ user.description }}</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import Vue from 'vue';
|
|
|
|
export default Vue.extend({
|
|
props: ['user']
|
|
});
|
|
</script>
|
|
|
|
<style lang="stylus" scoped>
|
|
.mk-user-preview
|
|
margin 0
|
|
padding 16px
|
|
font-size 12px
|
|
|
|
@media (min-width 350px)
|
|
font-size 14px
|
|
|
|
@media (min-width 500px)
|
|
font-size 16px
|
|
|
|
&:after
|
|
content ""
|
|
display block
|
|
clear both
|
|
|
|
> .avatar
|
|
display block
|
|
float left
|
|
margin 0 10px 0 0
|
|
width 48px
|
|
height 48px
|
|
border-radius 6px
|
|
|
|
@media (min-width 500px)
|
|
margin-right 16px
|
|
width 58px
|
|
height 58px
|
|
border-radius 8px
|
|
|
|
> .main
|
|
float left
|
|
width calc(100% - 58px)
|
|
|
|
@media (min-width 500px)
|
|
width calc(100% - 74px)
|
|
|
|
> header
|
|
@media (min-width 500px)
|
|
margin-bottom 2px
|
|
|
|
> .name
|
|
display inline
|
|
margin 0
|
|
padding 0
|
|
color #777
|
|
font-size 1em
|
|
font-weight 700
|
|
text-align left
|
|
text-decoration none
|
|
|
|
&:hover
|
|
text-decoration underline
|
|
|
|
> .username
|
|
text-align left
|
|
margin 0 0 0 8px
|
|
color #ccc
|
|
|
|
> .body
|
|
|
|
> .description
|
|
cursor default
|
|
display block
|
|
margin 0
|
|
padding 0
|
|
overflow-wrap break-word
|
|
font-size 1.1em
|
|
color #717171
|
|
|
|
</style>
|