Created
January 30, 2018 18:43
-
-
Save mitrallex/489cb82bfd44c04940578fd5f498944e to your computer and use it in GitHub Desktop.
PaginationComponent.vue
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<template> | |
<nav class="pagination is-centered is-rounded" role="navigation" aria-label="pagination"> | |
<a class="pagination-previous" @click.prevent="changePage(1)" :disabled="pagination.current_page <= 1">First page</a> | |
<a class="pagination-previous" @click.prevent="changePage(pagination.current_page - 1)" :disabled="pagination.current_page <= 1">Previous</a> | |
<a class="pagination-next" @click.prevent="changePage(pagination.current_page + 1)" :disabled="pagination.current_page >= pagination.last_page">Next page</a> | |
<a class="pagination-next" @click.prevent="changePage(pagination.last_page)" :disabled="pagination.current_page >= pagination.last_page">Last page</a> | |
<ul class="pagination-list"> | |
<li v-for="page in pages"> | |
<a class="pagination-link" :class="isCurrentPage(page) ? 'is-current' : ''" @click.prevent="changePage(page)">{{ page }}</a> | |
</li> | |
</ul> | |
</nav> | |
</template> | |
<style> | |
.pagination { | |
margin-top: 40px; | |
} | |
</style> | |
<script> | |
export default { | |
props: ['pagination', 'offset'], | |
methods: { | |
isCurrentPage(page) { | |
return this.pagination.current_page === page; | |
}, | |
changePage(page) { | |
if (page > this.pagination.last_page) { | |
page = this.pagination.last_page; | |
} | |
this.pagination.current_page = page; | |
this.$emit('paginate'); | |
} | |
}, | |
computed: { | |
pages() { | |
let pages = []; | |
let from = this.pagination.current_page - Math.floor(this.offset / 2); | |
if (from < 1) { | |
from = 1; | |
} | |
let to = from + this.offset - 1; | |
if (to > this.pagination.last_page) { | |
to = this.pagination.last_page; | |
} | |
while (from <= to) { | |
pages.push(from); | |
from++; | |
} | |
return pages; | |
} | |
} | |
} | |
</script> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment