src/components/image/ImageBanner.astro
---
/**
* ImageBanner
* Volledige breedte afbeeldingsbanner met tekstoverlay
*/
interface Props {
src?: string;
alt?: string;
headline?: string;
sub?: string;
}
const {
src = 'https://images.unsplash.com/photo-1460925895917-afdab827c52f?w=1400&q=80',
alt = 'Marketing team aan het werk',
headline = 'Groei begint met de juiste strategie',
sub = 'BLURR helpt ambitieuze merken verder.',
} = Astro.props;
---
<div class="ibann">
<div class="ibann__img-wrap">
<img class="ibann__img" src={src} alt={alt} loading="lazy" />
<div class="ibann__overlay"></div>
</div>
<div class="ibann__content">
{headline && <h2 class="ibann__headline">{headline}</h2>}
{sub && <p class="ibann__sub">{sub}</p>}
</div>
</div>
<style>
.ibann {
position: relative;
width: 100%;
min-height: 380px;
overflow: hidden;
display: flex;
align-items: center;
justify-content: center;
}
.ibann__img-wrap {
position: absolute;
inset: 0;
}
.ibann__img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}
.ibann__overlay {
position: absolute;
inset: 0;
background: linear-gradient(to bottom, rgba(10,10,10,0.35) 0%, rgba(10,10,10,0.65) 100%);
}
.ibann__content {
position: relative;
z-index: 1;
text-align: center;
padding: 3rem 1.5rem;
max-width: 740px;
}
.ibann__headline {
font-size: clamp(1.5rem, 3.5vw, 2.75rem);
font-weight: 800;
color: #fff;
margin: 0 0 0.6rem;
line-height: 1.15;
letter-spacing: -0.02em;
text-shadow: 0 2px 16px rgba(0,0,0,0.3);
}
.ibann__sub {
font-size: 1.05rem;
color: rgba(255,255,255,0.75);
margin: 0;
line-height: 1.5;
}
</style>
Props
| Prop | Type | Default | Beschrijving |
|---|---|---|---|
src | string | — | Afbeelding URL |
alt | string | — | Alt tekst |
headline | string | — | Headline overlay |
sub | string | — | Subtitel overlay |
* = verplicht