All files / src/hooks/queries useBrandsQuery.ts

0% Statements 0/11
0% Branches 0/9
0% Functions 0/3
0% Lines 0/10

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 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42                                                                                   
// src/hooks/queries/useBrandsQuery.ts
import { useQuery } from '@tanstack/react-query';
import { fetchAllBrands } from '../../services/apiClient';
import type { Brand } from '../../types';
 
/**
 * Query hook for fetching all brands (admin feature).
 *
 * @param enabled - Whether the query should run (default: true)
 * @returns TanStack Query result with Brand[] data
 *
 * @example
 * ```tsx
 * const { data: brands = [], isLoading, error } = useBrandsQuery();
 * ```
 */
export const useBrandsQuery = (enabled: boolean = true) => {
  return useQuery({
    queryKey: ['brands'],
    queryFn: async (): Promise<Brand[]> => {
      const response = await fetchAllBrands();
 
      if (!response.ok) {
        const error = await response.json().catch(() => ({
          message: `Request failed with status ${response.status}`,
        }));
        throw new Error(error.message || 'Failed to fetch brands');
      }
 
      const json = await response.json();
      // ADR-028: API returns { success: true, data: [...] }
      // If success is false or data is not an array, return empty array to prevent .map() errors
      if (!json.success || !Array.isArray(json.data)) {
        return [];
      }
      return json.data;
    },
    enabled,
    staleTime: 1000 * 60 * 5, // 5 minutes - brands don't change frequently
  });
};