Section

src/components/section.tsx
import React from 'react'
import { clsx } from 'clsx'
import { Container } from '@/components/container'
import { studioUrl } from '@/utils/studio-helpers'
interface SectionProps {
children: React.ReactNode
className?: string
innerAlign?: 'wide' | 'content' | 'none' | 'full' | 'navbar'
imageSrc?: string
imageAlt?: string
imageClassName?: string
overlayColor?: string
id?: string
}
export function Section({
children,
className,
innerAlign,
imageSrc,
imageAlt,
imageClassName,
overlayColor,
id,
}: SectionProps) {
return (
<section
id={id}
className={clsx('relative [&>*>*>*:last-child]:mb-0', className)}
>
{imageSrc && (
<>
<img
src={studioUrl(imageSrc, 'full')}
alt={imageAlt || ''}
className={clsx(
'object-cover object-center absolute inset-0 w-full h-full -z-[2]',
imageClassName
)}
/>
<div
className={clsx(
'absolute inset-0 -z-[1]',
overlayColor || 'bg-overlay/30'
)}
></div>
</>
)}
<Container {...(innerAlign && { align: innerAlign })}>
{children}
</Container>
</section>
)
}

Support

Talk to the developers of this project to learn more

We have been building professional websites for big clients for over 15 years. Gallop templates and blocks is our best foundation for SEO websites and web apps.

© 2026 Web Plant Media, LLC