import { ReactNode, useEffect, useState } from "react"; import MainBtn from "../MainBtn"; const data1:{ name: string; email: string; status: string; location: string; }[] = []; type PaginatedListProps = { data: any, itemsPerPage: number, filterItem?: string[], titleClass?:string, children: (data:any) => ReactNode; } export default function TableWrapper({ data = data1, itemsPerPage = 5, filterItem, children, }:PaginatedListProps) { const [isLoading, setIsLoading] = useState(true) const [searchTerm, setSearchTerm] = useState(""); const [filteredData, setFilteredData] = useState(data); const [currentPage, setCurrentPage] = useState(0); const [newData, setNewData] = useState<{ name: string; email: string; status: string; location: string; }[]>([]); const numberOfSelection = itemsPerPage; const handlePrev = () => { if (currentPage != 0) { setCurrentPage((prev:any) => prev - numberOfSelection); } }; const handleNext = () => { if (currentPage < data.length) { setCurrentPage((prev:any) => prev + numberOfSelection); } }; const handleSearch = ({ target: { value } }:{target: {value:string}}, name:string) => { setSearchTerm(value); let newFilteredData:any = data.filter((item:any) => item[name].toLowerCase().startsWith(value.toLowerCase()) ); setFilteredData(newFilteredData); setCurrentPage(0); }; useEffect(() => { setIsLoading(true) setTimeout(()=>{ setNewData( filteredData?.slice(currentPage, numberOfSelection + currentPage) ); setIsLoading(false) },1000) }, [currentPage, filteredData]); useEffect(()=>{ setCurrentPage(0) },[itemsPerPage]) return (
Loading...