120 lines
4.0 KiB
React
120 lines
4.0 KiB
React
import { useEffect, useState } from "react";
|
|
|
|
const data1 = [];
|
|
|
|
export default function NewPaginatedList({
|
|
data = data1,
|
|
itemsPerPage = 5,
|
|
filterItem,
|
|
tableTitle,
|
|
children,
|
|
}) {
|
|
const [searchTerm, setSearchTerm] = useState("");
|
|
const [filteredData, setFilteredData] = useState(data);
|
|
|
|
const [currentPage, setCurrentPage] = useState(0);
|
|
const [newData, setNewData] = useState([]);
|
|
|
|
const numberOfSelection = itemsPerPage;
|
|
|
|
const handlePrev = () => {
|
|
if (currentPage != 0) {
|
|
setCurrentPage((prev) => prev - numberOfSelection);
|
|
}
|
|
};
|
|
const handleNext = () => {
|
|
if (currentPage < data.length) {
|
|
setCurrentPage((prev) => prev + numberOfSelection);
|
|
}
|
|
};
|
|
|
|
const handleSearch = ({ target: { value } }, name) => {
|
|
setSearchTerm(value);
|
|
let newFilteredData = data.filter((item) =>
|
|
item[name].toLowerCase().startsWith(value.toLowerCase())
|
|
);
|
|
setFilteredData(newFilteredData);
|
|
setCurrentPage(0);
|
|
};
|
|
|
|
useEffect(() => {
|
|
setNewData(
|
|
filteredData?.slice(currentPage, numberOfSelection + currentPage)
|
|
);
|
|
}, [currentPage, filteredData]);
|
|
console.log("newData", newData, filteredData);
|
|
return (
|
|
<div className="w-full">
|
|
<h1 className="text-2xl mb-5 font-semibold">{tableTitle}</h1>
|
|
|
|
{data.length > 0 && filterItem && (
|
|
<div className="mb-10 flex justify-end items-center gap-2">
|
|
{filterItem.map((item, index) => (
|
|
<label
|
|
key={index}
|
|
className="flex flex-col sm:flex-row items-center gap-2 text-slate-600 dark:text-slate-100 transition-all duration-500"
|
|
>
|
|
Search by {item[0].toUpperCase() + item.slice(1)}
|
|
<input
|
|
name={item}
|
|
type="text"
|
|
className="py-1 px-2 text-sm min-w-[100px] text-black dark:text-white bg-white dark:bg-slate-800 rounded-full border-0 outline-none ring-1 ring-slate-300 dark:ring-white transition-all duration-500"
|
|
value={searchTerm}
|
|
onChange={(e) => {
|
|
handleSearch(e, item);
|
|
}}
|
|
/>
|
|
</label>
|
|
))}
|
|
</div>
|
|
)}
|
|
|
|
{children({ data: newData })}
|
|
|
|
{/* show prev and next button if data exist */}
|
|
{data.length > 0 && (
|
|
<div className="mt-10 w-full flex gap-4 justify-center items-center">
|
|
<button
|
|
onClick={handlePrev}
|
|
className={`w-12 h-12 rounded-full flex justify-center items-center transition-all duration-300 ${
|
|
currentPage == 0
|
|
? "text-slate-400 border-slate-400 dark:text-slate-400 dark:border-slate-400 pointer-events-none"
|
|
: "text-slate-600 border-slate-600 dark:text-white dark:border-white"
|
|
}`}
|
|
>
|
|
<
|
|
</button>
|
|
|
|
{data.length && data.map((item, index)=>{
|
|
if(index%itemsPerPage == 0 && index >= currentPage && index <= currentPage+itemsPerPage){
|
|
return (
|
|
<button
|
|
onClick={handleNext}
|
|
className={`w-12 h-12 rounded-full flex justify-center items-center border transition-all duration-300 ${
|
|
currentPage != index
|
|
? "text-slate-400 border-slate-400 dark:text-slate-400 dark:border-slate-400"
|
|
: "text-slate-600 border-slate-600 dark:text-white dark:border-white pointer-events-none"
|
|
}`}
|
|
>
|
|
{index/itemsPerPage +1}
|
|
</button>
|
|
)
|
|
}
|
|
})}
|
|
|
|
<button
|
|
onClick={handleNext}
|
|
className={`w-12 h-12 rounded-full flex justify-center items-center transition-all duration-300 ${
|
|
currentPage + numberOfSelection >= data.length
|
|
? "text-slate-400 border-slate-400 dark:text-slate-400 dark:border-slate-400 pointer-events-none"
|
|
: "text-slate-600 border-slate-600 dark:text-white dark:border-white"
|
|
}`}
|
|
>
|
|
>
|
|
</button>
|
|
</div>
|
|
)}
|
|
</div>
|
|
);
|
|
}
|