vuepress-theme-reco/components/NoteAbstractItem.vue

93 lines
2.0 KiB
Vue
Raw Normal View History

<template>
<div
class="abstract-item">
<i v-if="item.frontmatter.sticky" class="iconfont reco-place-to-top"></i>
<div class="title">
<i v-if="item.frontmatter.keys" class="iconfont reco-lock"></i>
<router-link :to="item.path">{{item.title}}</router-link>
</div>
<div class="abstract" v-html="item.excerpt"></div>
<hr>
<PageInfo
:pageInfo="item"
:hideAccessNumber="!(hideAccessNumber !== true)"
:currentTag="currentTag">
</PageInfo>
</div>
</template>
<script>
import PageInfo from './PageInfo'
export default {
components: { PageInfo },
props: ['item', 'currentPage', 'currentTag', 'hideAccessNumber']
}
</script>
<style lang="stylus" scoped>
@require '../styles/recoConfig.styl'
.abstract-item
position relative
margin: 0 auto 20px;
padding: 16px 20px;
width 100%
overflow: hidden;
border-radius: $borderRadius
box-shadow: $boxShadow;
box-sizing: border-box;
transition all .3s
background-color $bgColor
.reco-place-to-top
position absolute
top -5px
left -3px
display inline-block
color $accentColor
font-size 2.4rem
&:hover
box-shadow: $boxShadowHover
.title
position: relative;
font-size: 1.28rem;
line-height: 36px;
display: inline-block;
a
color $textColor
.reco-lock
font-size 1.28rem
color $accentColor
&:after
content: "";
position: absolute;
width: 100%;
height: 2px;
bottom: 0;
left: 0;
background-color: $accentColor;
visibility: hidden;
-webkit-transform: scaleX(0);
transform: scaleX(0);
transition: .3s ease-in-out;
&:hover a
color $accentColor
&:hover:after
visibility visible
-webkit-transform: scaleX(1);
transform: scaleX(1);
.tags
.tag-item
cursor: pointer;
&.active
color $accentColor
&:hover
color $accentColor
@media (max-width: $MQMobile)
.tags
display block
margin-top 1rem;
margin-left: 0!important;
</style>