All files / src/components ErrorSummary.tsx

73.33% Statements 11/15
100% Branches 0/0
50% Functions 4/8
73.33% Lines 11/15

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 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68                                1x               1x                 1x 1x     1x 1x     1x 1x 1x     1x                 1x                        
import { useEffect } from 'react'
 
import { FormikErrors, FormikValues } from 'formik'
import { Namespace, TFunction } from 'i18next'
 
export interface ErrorSummaryItem {
  feildId: string
  errorMessage: string
}
 
export interface ErrorSummaryProps {
  id: string
  errors: ErrorSummaryItem[]
  summary: string
}
 
export const getErrorSummaryItem = (
  feildId: string,
  errorMessage: string,
): ErrorSummaryItem => ({
  feildId,
  errorMessage,
})
 
export const getErrorSummaryItems = <T extends FormikValues>(
  formErrors: FormikErrors<T>,
  t: TFunction<Namespace, undefined>,
) => {
  return Object.keys(formErrors)
    .filter((key) => !!formErrors[key])
    .map((key) => getErrorSummaryItem(key, t(formErrors[key] as any)))
}
 
export const goToErrorSummary = (errorSummaryId: string) => {
  const errorSummaryEl = document.querySelector<HTMLElement>(
    `#${errorSummaryId}`,
  )
  errorSummaryEl?.scrollIntoView({ behavior: 'smooth', block: 'center' })
  errorSummaryEl?.focus()
}
 
const ErrorSummary = ({ id, errors, summary }: ErrorSummaryProps) => {
  useEffect(() => {
    goToErrorSummary(id)
  }, [id])
 
  return (
    <section
      id={id}
      className="mb-5 border-l-6 border-accent-error p-5"
      tabIndex={-1}
    >
      <h2 className="mb-3 text-2xl font-bold">{summary}</h2>
      <ul className="list-disc space-y-2 pl-10">
        {errors.map(({ feildId, errorMessage }) => (
          <li key={feildId}>
            <a className="visited:text-link-default" href={`#${feildId}`}>
              {errorMessage}
            </a>
          </li>
        ))}
      </ul>
    </section>
  )
}
 
export default ErrorSummary