Pagination.svelte 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. <script lang="ts">
  2. import { Pagination } from 'bits-ui';
  3. import { createEventDispatcher } from 'svelte';
  4. import ChevronLeft from '../icons/ChevronLeft.svelte';
  5. import ChevronRight from '../icons/ChevronRight.svelte';
  6. export let page = 0;
  7. export let count = 0;
  8. export let perPage = 20;
  9. </script>
  10. <div class="flex justify-center">
  11. <Pagination.Root bind:page {count} {perPage} let:pages>
  12. <div class="my-2 flex items-center">
  13. <Pagination.PrevButton
  14. class="mr-[25px] inline-flex size-8 items-center justify-center rounded-[9px] bg-transparent hover:bg-gray-100 dark:hover:bg-gray-800 active:scale-98 disabled:cursor-not-allowed disabled:text-gray-400 dark:disabled:text-gray-700 hover:disabled:bg-transparent dark:hover:disabled:bg-transparent"
  15. >
  16. <ChevronLeft className="size-4" strokeWidth="2" />
  17. </Pagination.PrevButton>
  18. <div class="flex items-center gap-2.5">
  19. {#each pages as page (page.key)}
  20. {#if page.type === 'ellipsis'}
  21. <div class="text-sm font-medium text-foreground-alt">...</div>
  22. {:else}
  23. <Pagination.Page
  24. {page}
  25. class="inline-flex size-8 items-center justify-center rounded-[9px] bg-transparent hover:bg-gray-100 dark:hover:bg-gray-800 text-sm font-medium hover:bg-dark-10 active:scale-98 disabled:cursor-not-allowed disabled:opacity-50 hover:disabled:bg-transparent data-[selected]:bg-black data-[selected]:text-gray-100 data-[selected]:hover:bg-black dark:data-[selected]:bg-white dark:data-[selected]:text-gray-900 dark:data-[selected]:hover:bg-white"
  26. >
  27. {page.value}
  28. </Pagination.Page>
  29. {/if}
  30. {/each}
  31. </div>
  32. <Pagination.NextButton
  33. class="ml-[25px] inline-flex size-8 items-center justify-center rounded-[9px] bg-transparent hover:bg-gray-100 dark:hover:bg-gray-800 active:scale-98 disabled:cursor-not-allowed disabled:text-gray-400 dark:disabled:text-gray-700 hover:disabled:bg-transparent dark:hover:disabled:bg-transparent"
  34. >
  35. <ChevronRight className="size-4" strokeWidth="2" />
  36. </Pagination.NextButton>
  37. </div>
  38. </Pagination.Root>
  39. </div>