import React, { useState } from "react"; import { useEffect } from "react"; import styles from "../../styles/exos/Paginaton.module.scss"; import { parseClassName } from "../../utils/utils.js"; export function Pagination({ pages, setPage, page }) { var pages = new Array(pages - 1).fill(0).reduce( (p, n, i) => { return [...p, i + 2]; }, [1] ) return (
{page != 0 && (

{ setPage(page - 1); }} className={styles["pagination-page"]} > «

)} {pages.length <= 9 && pages.map((p, i) => { return (

{ setPage && setPage(p - 1); }} className={parseClassName([ styles["pagination-page"], (page == p - 1 ? styles["pagination-page-active"] : undefined)]) } > {p}

); })} {pages.length > 9 && ( <> {page >= 6 && ( <>

{ setPage(pages[0] - 1); }} className={styles["pagination-page"]} > {pages[0]}

...

)} {pages .slice( page < 6 ? 0 : page - 2, page < 4 ? 5 : page + 1 > pages.length - 4 ? pages.length : page + 3 ) .map((p) => { console.log("new pagin", p); return (

{ setPage(p - 1); }} className={parseClassName([ styles["pagination-page"], page == p - 1 ? styles["pagination-page-active"] : undefined, ])} > {p}

); })} {page + 1 <= pages.length - 4 && ( <>

...

{ setPage(pages[pages.length - 1] - 1); }} > {pages[pages.length - 1]}

)} )} {page != pages.length - 1 && (

{ setPage(page + 1); }} className={styles["pagination-page"]} > »

)}
); }