All files / hook useEpreuveFiltered.ts

100% Statements 5/5
100% Branches 0/0
100% Functions 2/2
100% Lines 4/4

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 242x   2x                             2x         6x  
import { useMemo } from "react";
import {Epreuve, EpreuveCardType, EpreuveFilters} from "@/type/evenement/epreuve";
import {filterEpreuves} from "@/lib/filter/epreuveFilter";
 
/**
 * Hook personnalisé pour filtrer des épreuves avec mémorisation
 * Utilise useMemo pour optimiser les performances en évitant le recalcul inutile
 * @param epreuveCards - Liste des épreuves au format carte à filtrer
 * @param filters - Critères de filtrage à appliquer
 * @param fullEpreuves - Liste complète des épreuves (optionnel, nécessaire pour certains filtres)
 * @returns Liste filtrée des épreuves mémorisée
 * @example
 * const filteredEpreuves = useFilteredEpreuves(epreuves, {
 *   libelle: 'natation',
 *   date: '2024-07-26'
 * });
 */
export function useFilteredEpreuves(
  epreuveCards: EpreuveCardType[],
  filters: EpreuveFilters,
  fullEpreuves?: Epreuve[]
) {
  return useMemo(() => filterEpreuves(epreuveCards, filters, fullEpreuves), [epreuveCards, filters, fullEpreuves]);
}