A advanced, smart, highly customizable vue pagination component for Laravel Pagination
See https://shibbirweb.github.io/advanced-laravel-vue-paginate
npm install advanced-laravel-vue-paginate --saveRegister the component:
// register as a global Vue component
import 'advanced-laravel-vue-paginate/dist/advanced-laravel-vue-paginate.css'
Vue.use(require('advanced-laravel-vue-paginate'));
// or, import as a single Vue component
import AdvancedLaravelVuePaginate from 'advanced-laravel-vue-paginate';
import 'advanced-laravel-vue-paginate/dist/advanced-laravel-vue-paginate.css'
// register in vue component
export default {
	components: {
		AdvancedLaravelVuePaginate
	}
}
// or, use as a cdn
<script src="https://unpkg.com/vue/dist/vue.min.js"></script>
<script src="https://unpkg.com/advanced-laravel-vue-paginate"></script>Use the component:
<ul>
    <li v-for="post in laravelData.data" :key="post.id">{{ post.title }}</li>
</ul>
<advanced-laravel-vue-paginate :data="laravelData" @paginateTo="getResults"/>export default {
	data() {
		return {
			// Our data object that holds the Laravel paginator data
			laravelData: {},
		}
	},
	mounted() {
		// Fetch initial results
		this.getResults();
	},
	methods: {
		// Our method to GET results from a Laravel endpoint
		getResults(page = 1) {
			axios.get('example/results?page=' + page)
				.then(response => {
					this.laravelData = response.data;
				});
		}
	}
}| Name | Type | Parameter | Default | Description | 
|---|---|---|---|---|
| data | Object(required) | Laravel paginate default object | An object containing the structure of a Laravel paginator response. | |
| onEachSide | Number(optional) | Any Integernumber | 3 | Number of page number show each side of current page. Any negative value show all page links. | 
| showNextPrev | Boolean(optional) | 
 | true | Show next/previous button. truefor show Next/Previous button andfalsefor hide next/previous button | 
| dots | String(optional) | Any String value | ... | Symbol for hidden page numbers | 
| previousText | String(optional) | Any Stringvalue | Previous | Text for previous button | 
| nextText | String(optional) | Any Stringvalue | Next | Text for next button | 
| useStyle | String(optional) | 
 | default | 
 | 
| alignment | String (optional) | 
 | null | Custom alignment of pagination. nullfor default style,leftfor align to left,centerfor align to center,rightfor align to right | 
| activeClass | String(optional) | Any Stringvalue | active | Class for current pagination page | 
| listClass | String(optional) | Any Stringvalue | pagination | List ( ul) class | 
| listItemClass | String(optional) | Any Stringvalue | page-item | Class for List item ( li) | 
| contentAlignClass | String(optional) | Any Stringvalue | justify-content-center | Content align class | 
| linkClass | String(optional) | Any Stringvalue | page-link | Anchor link ( a) class | 
| disableClass | String(optional) | Any Stringvalue | disabled | Disable class name | 
###Events
| Name | Return | Description | 
|---|---|---|
| paginateTo | Number | Invoked when user click on a pagination link and return clicked page number | 
npm install
npm run serve