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 114 115 | 2x 2x 2x 2x 2x 2x 2x 2x | import { Fragment } from 'react' import Markdown from 'markdown-to-jsx' import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' import { icon } from '../../lib/loadIcons' export interface ContactSectionRowDetailItem { link?: string content?: string } export interface ContactSectionRowProps { title?: string detail?: string highlight?: boolean iconFeature?: string button?: boolean buttonURL?: string buttonId?: string items: ContactSectionRowDetailItem[] refPageAA: string id: string lang: string } export const ContactSectionRow = ({ lang, title, highlight, iconFeature, button, buttonId, items, refPageAA = 'mscaPlaceholder', id = 'mscaPlaceholder', }: ContactSectionRowProps) => { const locale = lang === 'fr' ? 'fr' : 'en' const newTabTaskExceptions = [ 'https://www.servicecanada.gc.ca/tbsc-fsco/sc-hme.jsp?lang=eng', 'https://www.servicecanada.gc.ca/tbsc-fsco/sc-hme.jsp?lang=fra', 'https://eservices.canada.ca/en/service/', 'https://eservices.canada.ca/fr/service/', 'https://ep-be.alpha.service.canada.ca/en', 'https://ep-be.alpha.service.canada.ca/fr', ] return ( <div className={`grid grid-cols-1 py-2 md:grid-cols-12 ${''}`}> <dt className={`text-2xl font-bold text-gray-darker md:col-span-4 md:pl-3 ${ highlight && 'bg-blue-100 py-2' }`} > {title} </dt> <dd className={`prose max-w-none prose-p:my-0 prose-p:font-body prose-p:text-xl md:col-span-8 ${ highlight && 'bg-blue-100 py-2' }`} > {items.map((item) => { return ( <Fragment key={item.content}> {button ? ( <a id={'test-card-button-' + buttonId} data-cy="contact-us-button" href={item.link} className="rounded-sm px-3.5 py-1.5 font-display text-xl leading-[23px] text-blue-default underline visited:text-purple-50a hover:text-blue-hover focus:outline-1 focus:outline-blue-hover active:text-blue-hover" aria-label={` ${item.content} - ${ item.link && newTabTaskExceptions.includes(item.link) ? locale === 'fr' ? "S'ouvre dans un nouvel onglet" : 'Opens in a new tab' : "S'ouvre dans un nouvel onglet" }`} target={ item.link && newTabTaskExceptions.includes(item.link) ? '_blank' : '_self' } rel={ item.link && newTabTaskExceptions.includes(item.link) ? 'noopener noreferrer' : undefined } data-gc-analytics-customclick={`ESDC-EDSC_MSCA-MSDC-SCH:${refPageAA}:${id}`} > {item.content} <FontAwesomeIcon className="ml-2" width="14" icon={icon['arrow-up-right-from-square']} ></FontAwesomeIcon> </a> ) : ( <div className="prose flex px-2 align-baseline text-xl even:pt-4 prose-p:font-body prose-ul:my-0 prose-li:font-body prose-li:marker:text-black"> {iconFeature && ( <FontAwesomeIcon className="pr-2 pt-1" style={{ color: '#2572B4' }} icon={icon[iconFeature as keyof typeof icon]} /> )} {item.content && <Markdown>{item.content}</Markdown>} </div> )} </Fragment> ) })} </dd> </div> ) } |