vuepress-theme-reco/components/NoteAbstract.vue

53 lines
1.3 KiB
Vue
Raw Normal View History

2019-04-15 10:35:40 +08:00
<template>
<div class="abstract-wrapper">
<div v-if="listLoadType === 'sync'" key="sync">
<NoteAbstractItem
v-for="(item, index) in data"
:key="item.path"
:item="item"
:currentPage="currentPage"
:currentTag="currentTag"
v-show="index >= (currentPage * 10 - 10) && index < currentPage * 10"/>
</div>
<div v-else-if="listLoadType === 'async'" key="async">
<NoteAbstractItem
2019-11-13 15:55:16 +08:00
v-for="(item) in currentPageData"
:key="item.path"
:item="item"
:currentPage="currentPage"
:currentTag="currentTag"
:hideAccessNumber="true" />
2019-04-15 10:35:40 +08:00
</div>
</div>
</template>
<script>
import NoteAbstractItem from './NoteAbstractItem'
2019-04-15 10:35:40 +08:00
export default {
components: { NoteAbstractItem },
props: ['data', 'currentPage', 'currentTag', 'hideAccessNumber'],
computed: {
listLoadType () {
const valineConfig = this.$themeConfig.valineConfig
2019-11-24 16:06:16 +08:00
if (this.$frontmatter.home) return 'async'
2019-11-13 15:55:16 +08:00
if (valineConfig && !valineConfig.hideListAccessNumber) {
return 'sync'
} else {
return 'async'
}
},
currentPageData () {
const start = this.currentPage * 10 - 10
const end = this.currentPage * 10
return this.data.slice(start, end)
}
}
2019-04-15 10:35:40 +08:00
}
</script>
<style lang="stylus" scoped>
.abstract-wrapper
width 100%
</style>