61 lines
2.8 KiB
Vue
61 lines
2.8 KiB
Vue
<script setup>
|
|
import { Link } from '@inertiajs/inertia-vue3';
|
|
|
|
defineProps({
|
|
links: {
|
|
type: Object,
|
|
default: () => ({}),
|
|
},
|
|
data: {
|
|
type: Object,
|
|
default: () => ({}),
|
|
}
|
|
});
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
|
<ul v-if="links.length > 3" class="inline-flex -space-x-px">
|
|
<template v-for="(link, p) in links" :key="p">
|
|
|
|
<li v-if="link.url === null" class="bg-white border border-gray-300 text-gray-500 hover:bg-gray-100 hover:text-gray-700 ml-0 rounded-l-lg leading-tight py-2 px-3 dark:bg-gray-800 dark:border-gray-700 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white" v-html=""/>
|
|
<a href="#"
|
|
class="bg-white border border-gray-300 text-gray-500 hover:bg-gray-100 hover:text-gray-700 leading-tight py-2 px-3 dark:bg-gray-800 dark:border-gray-700 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white">1</a>
|
|
</li>
|
|
<li>
|
|
<a href="#"
|
|
class="bg-white border border-gray-300 text-gray-500 hover:bg-gray-100 hover:text-gray-700 leading-tight py-2 px-3 dark:bg-gray-800 dark:border-gray-700 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white">2</a>
|
|
</li>
|
|
<li>
|
|
<a href="#" aria-current="page"
|
|
class="bg-blue-50 border border-gray-300 text-blue-600 hover:bg-blue-100 hover:text-blue-700 py-2 px-3 dark:border-gray-700 dark:bg-gray-700 dark:text-white">3</a>
|
|
</li>
|
|
<li>
|
|
<a href="#"
|
|
class="bg-white border border-gray-300 text-gray-500 hover:bg-gray-100 hover:text-gray-700 leading-tight py-2 px-3 dark:bg-gray-800 dark:border-gray-700 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white">4</a>
|
|
</li>
|
|
<li>
|
|
<a href="#"
|
|
class="bg-white border border-gray-300 text-gray-500 hover:bg-gray-100 hover:text-gray-700 leading-tight py-2 px-3 dark:bg-gray-800 dark:border-gray-700 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white">5</a>
|
|
</li>
|
|
<li>
|
|
<a href="#"
|
|
class="bg-white border border-gray-300 text-gray-500 hover:bg-gray-100 hover:text-gray-700 rounded-r-lg leading-tight py-2 px-3 dark:bg-gray-800 dark:border-gray-700 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white">Next</a>
|
|
</li>
|
|
</template>
|
|
</ul>
|
|
|
|
<div v-if="links.length > 3">
|
|
<div class="flex flex-wrap -mb-1">
|
|
<template v-for="(link, p) in links" :key="p">
|
|
<div v-if="link.url === null" class="mr-1 mb-1 px-4 py-3 text-sm leading-4 text-gray-400 border rounded"
|
|
v-html="link.label" />
|
|
<Link v-else
|
|
class="mr-1 mb-1 px-4 py-3 text-sm leading-4 border rounded hover:bg-white focus:border-indigo-500 focus:text-indigo-500"
|
|
:class="{ 'bg-blue-700 text-white': link.active }" method="post" :data="data" :href="link.url" v-html="link.label" as="button" />
|
|
</template>
|
|
</div>
|
|
</div>
|
|
</template>
|