-
Notifications
You must be signed in to change notification settings - Fork 86
/
PostsList.vue
105 lines (91 loc) · 1.81 KB
/
PostsList.vue
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
<template>
<div class="main-div posts-list">
<TransitionFadeSlide>
<div
v-if="listPosts.length === 0"
class="no-posts"
key="no-posts"
>
{{ $themeConfig.lang.noRelatedPosts }}
</div>
<div
v-else
class="posts-items"
:key="page"
>
<TransitionFadeSlide
tag="div"
direction="x"
group
>
<PostsListItem
v-for="post in pagePosts"
:key="post.path"
:post="post"
:each-side="2"
/>
</TransitionFadeSlide>
</div>
</TransitionFadeSlide>
<div
v-if="total > 1"
class="posts-paginator"
>
<Pagination
v-model="page"
:total="total"
/>
</div>
</div>
</template>
<script>
import TransitionFadeSlide from './TransitionFadeSlide.vue'
import PostsListItem from './PostsListItem.vue'
import Pagination from './Pagination.vue'
export default {
name: 'PostsList',
components: {
TransitionFadeSlide,
PostsListItem,
Pagination,
},
props: {
posts: {
type: Array,
required: false,
default: null,
},
},
data () {
return {
page: 1,
}
},
computed: {
perPage () {
return this.$themeConfig.pagination.perPage || 5
},
total () {
return Math.ceil(this.listPosts.length / this.perPage)
},
listPosts () {
return this.posts || this.$posts
},
pagePosts () {
const begin = (this.page - 1) * this.perPage
const end = begin + this.perPage
return this.listPosts.slice(begin, end)
},
},
watch: {
listPosts () {
this.page = 1
},
},
}
</script>
<style lang="stylus" scoped>
@require '~@theme/styles/variables'
.no-posts
color $grayTextColor
</style>