All files / apps/timeOff/src/screens/ChooseDate/hooks useQuickSelectOptions.ts

100% Statements 9/9
50% Branches 1/2
100% Functions 4/4
100% Lines 8/8

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                    1x 17x 17x   17x   17x             17x 17x       17x              
import { useMemo } from 'react';
 
import type { QuickSelectValue } from '@repo/ui/components/QuickSelect';
 
import { useHolidayCalendar } from '@/hooks/useHolidayCalendar';
 
import { generateDynamicQuickSelectOptions } from '../utils';
 
import { getFallbackValue } from './helpers';
 
export const useQuickSelectOptions = () => {
  const currentYear = useMemo(() => new Date().getFullYear(), []);
  const { holidays, makeUpWorkdays } = useHolidayCalendar(currentYear);
 
  const quickSelectOptions = useMemo(
    () =>
      generateDynamicQuickSelectOptions({
        holidays,
        makeUpWorkdays,
      }),
    [holidays, makeUpWorkdays],
  );
 
  const defaultSuggestedValue = useMemo<QuickSelectValue>(
    () => quickSelectOptions[0]?.value || getFallbackValue(),
    [quickSelectOptions],
  );
 
  return {
    holidays,
    makeUpWorkdays,
    quickSelectOptions,
    defaultSuggestedValue,
  };
};