All files / components ContextualAlert.tsx

100% Statements 12/12
50% Branches 7/14
100% Functions 1/1
100% Lines 11/11

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 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113  2x 2x 2x 2x 2x 2x                         2x                     2x                 2x               2x                                                                                                                               2x  
import { ReactNode } from 'react'
import Image from 'next/image'
import success_img from '../public/success_img.svg'
import warning_img from '../public/warning_img.svg'
import danger_img from '../public/danger_img.svg'
import info_img from '../public/info_img.svg'
import Markdown from 'markdown-to-jsx'
 
export interface ContextualAlertProps {
  id: string
  type?: string
  alert_icon_id: string
  alert_icon_alt_text: string
  alertHeading: string | ReactNode
  alertBody: string
  whiteBG?: boolean
  className?: string
}
 
const ContextualAlert = ({
  id,
  type,
  alert_icon_id,
  alert_icon_alt_text,
  alertHeading,
  alertBody,
  whiteBG,
  className,
}: ContextualAlertProps) => {
  const alert_type =
    type === 'warning'
      ? warning_img
      : type === 'danger'
        ? danger_img
        : type === 'information'
          ? info_img
          : success_img
 
  const alert_color =
    type === 'warning'
      ? 'border-orange-dark'
      : type === 'danger'
        ? 'border-red-50b'
        : type === 'information'
          ? 'border-brighter-blue-dark'
          : 'border-green-50a'
 
  const white_BG = whiteBG ? 'bg-white' : ' '
 
  return (
    <li
      id={id}
      className={`relative min-w-72 pl-4 sm:pl-6 ${white_BG} ${className}`}
    >
      <div
        data-testid="alert-icon"
        className="absolute left-1.5 top-3 bg-white py-1 sm:left-3.5"
      >
        <Image
          src={alert_type}
          width={28}
          height={28}
          alt={alert_icon_alt_text}
          id={alert_icon_id}
        ></Image>
      </div>
      <div
        className={`overflow-auto border-l-[6px] ${alert_color} py-3 pl-6 leading-8`}
      >
        <div className="ml-1 font-display text-2xl font-bold leading-[26px] text-deep-blue-dark">
          {alertHeading}
        </div>
 
        <div className="ml-0.5 font-body text-20px text-gray-darker">
          <Markdown
            options={{
              overrides: {
                h2: {
                  props: {
                    className:
                      'text-3xl text-gray-darker font-display font-bold mt-10 mb-3',
                  },
                },
                p: {
                  props: {
                    className: 'mb-3 text-gray-darker',
                  },
                },
                ul: {
                  props: {
                    className: 'list-disc ml-4 sm:mx-8 mb-3 text-gray-darker',
                  },
                },
                a: {
                  props: {
                    className: 'underline text-deep-blue-dark cursor-pointer',
                    rel: 'noopener noreferrer', // Security, avoids external site opened through this site to have control over this site
                    target: '_blank',
                  },
                },
              },
            }}
          >
            {alertBody}
          </Markdown>
        </div>
      </div>
    </li>
  )
}
 
export default ContextualAlert