All files / src/features/auth/hooks use-auth-form.ts

100% Statements 7/7
100% Branches 5/5
100% Functions 3/3
100% Lines 7/7

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 43 44 45 46 47 48                              6x   6x                               10x   10x 2x 1x       10x            
import { useCallback } from 'react';
import { useAuthStore } from '@/store/auth-store';
 
/**
 * Hook for auth form state management
 */
export function useAuthFormState() {
  const {
    error,
    clearError,
    isSigningIn,
    isSigningUp,
    isLoggingOut,
    rememberMe,
    setRememberMe,
  } = useAuthStore();
 
  return {
    error,
    clearError,
    isSigningIn,
    isSigningUp,
    isLoggingOut,
    rememberMe,
    setRememberMe,
    isLoading: isSigningIn || isSigningUp || isLoggingOut,
  };
}
 
/**
 * Hook for form field error handling
 */
export function useFormFieldError() {
  const { error, clearError } = useAuthStore();
 
  const handleFieldFocus = useCallback(() => {
    if (error) {
      clearError();
    }
  }, [error, clearError]);
 
  return {
    handleFieldFocus,
    hasError: !!error,
    error,
  };
}