2024-01-07 03:40:42 +08:00

99 lines
2.1 KiB
Vue

<script lang="ts" setup>
import { computed } from 'vue'
import { useBlogExtract, useThemeLocaleData } from '../composables/index.js'
import AutoLink from './AutoLink.vue'
import IconArchive from './icons/IconArchive.vue'
import IconTag from './icons/IconTag.vue'
const theme = useThemeLocaleData()
const avatar = computed(() => theme.value.avatar)
const { hasBlogExtract, tags, archives } = useBlogExtract()
</script>
<template>
<div v-if="avatar" class="blog-aside-wrapper">
<div class="avatar-profile">
<p v-if="avatar.url">
<img :src="avatar.url" :alt="avatar.name">
</p>
<div>
<h3>{{ avatar.name }}</h3>
<p>{{ avatar.description }}</p>
</div>
</div>
<div v-if="hasBlogExtract" class="blog-nav">
<AutoLink class="nav-link" :href="tags.link">
<IconTag class="icon" />
<span>{{ tags.text }}</span>
</AutoLink>
<AutoLink class="nav-link" :href="archives.link">
<IconArchive class="icon" />
<span>{{ archives.text }}</span>
</AutoLink>
</div>
</div>
</template>
<style scoped>
.blog-aside-wrapper {
position: sticky;
top: calc(var(--vp-nav-height) + 2rem);
display: none;
width: 270px;
padding: 1rem 0;
margin-top: 2rem;
margin-bottom: 12rem;
margin-left: 2rem;
text-align: center;
border-left: solid 1px var(--vp-c-divider);
}
.blog-aside-wrapper img {
width: 50%;
margin: auto;
}
.blog-aside-wrapper h3 {
margin-top: 1.5rem;
font-size: 16px;
font-weight: 600;
}
@media (min-width: 768px) {
.blog-aside-wrapper {
display: block;
}
}
.blog-nav {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 16px;
padding: 10px 12px 0;
margin: 24px 24px 0;
border-top: solid 1px var(--vp-c-divider);
}
.nav-link {
display: flex;
align-items: center;
justify-content: center;
padding: 3px;
font-weight: 600;
color: var(--vp-c-brand-1);
border-radius: 8px;
transition: all var(--t-color);
}
.nav-link:hover {
color: var(--vp-c-brand-2);
}
.nav-link .icon {
width: 1em;
height: 1em;
margin-right: 4px;
}
</style>