62 lines
1.9 KiB
JavaScript
62 lines
1.9 KiB
JavaScript
import Button from '@hashicorp/react-button'
|
|
import InlineSvg from '@hashicorp/react-inline-svg'
|
|
import RightArrowIcon from './img/right-arrow-icon.svg?include'
|
|
|
|
export default function BasicHero({
|
|
heading,
|
|
content,
|
|
links,
|
|
brand,
|
|
backgroundImage,
|
|
}) {
|
|
return (
|
|
<div className={`g-basic-hero ${backgroundImage ? 'has-background' : ''}`}>
|
|
<div className="g-grid-container">
|
|
<h1 className="g-type-display-1">{heading}</h1>
|
|
{content && <p className="g-type-body-large">{content}</p>}
|
|
{links && links.length > 0 && (
|
|
<>
|
|
<div className="links">
|
|
{links.slice(0, 2).map((link, stableIdx) => {
|
|
const buttonVariant = stableIdx === 0 ? 'primary' : 'secondary'
|
|
const linkType = link.type || 'inbound'
|
|
|
|
return (
|
|
<Button
|
|
// eslint-disable-next-line react/no-array-index-key
|
|
key={stableIdx}
|
|
linkType={linkType}
|
|
theme={{
|
|
variant: buttonVariant,
|
|
brand,
|
|
background: 'light',
|
|
}}
|
|
title={link.text}
|
|
url={link.url}
|
|
/>
|
|
)
|
|
})}
|
|
</div>
|
|
{links[2] && (
|
|
<div className="third-link">
|
|
<a
|
|
href={links[2].url}
|
|
rel="noopener noreferrer"
|
|
target="_blank"
|
|
>
|
|
<span className="g-type-buttons-and-standalone-links">
|
|
{links[2].text}
|
|
</span>
|
|
<span className="icon">
|
|
<InlineSvg src={RightArrowIcon} />
|
|
</span>
|
|
</a>
|
|
</div>
|
|
)}
|
|
</>
|
|
)}
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|