I am unable to filter and sort at the same time. I will be getting products
from axios get call and create a copy of it into filteredProducts
initially. Then i will be clicking on sort
and discount
filter options. Sorting is working fine here but not together with discount
filter. How can i achieve this together inside useEffect
?
const [filteredProducts, setFilteredProducts] = useState([]);
const handleSort = (sortByValue) => {
return filteredProducts.sort((a, b) => {
switch(sortByValue) {
case 'new' : return parseISO(b.created_at) - parseISO(a.created_at);
case 'discount' : return b.discount - a.discount;
case 'price_desc' : return b.price - a.price;
case 'price_asc' : return a.price - b.price;
default : return a.name.localeCompare(b.name);
}
})
}
const discount = queryParams.get('discount')
const sortBy = queryParams.get('sort')
const handleDiscountFilters = (filterResults) => {
if(discount) {
return filteredProducts.filter((product) => product.discount > discount)
} else {
return products
}
}
// Here i want to call the different filter functions first and then call sort function.
useEffect(() => {
let filterResults = [...filteredProducts];
filterResults = handleDiscountFilters(filterResults)
filterResults = handleSort(sortBy)
setFilteredProducts(filterResults);
}, [filteredProducts, handleDiscountFilters, handleSort, sortBy])