diff options
| author | Dawid Rycerz <dawid@rycerz.xyz> | 2025-07-22 15:08:37 +0300 |
|---|---|---|
| committer | Dawid Rycerz <dawid@rycerz.xyz> | 2025-07-22 15:08:37 +0300 |
| commit | fcc2f4704e39b0e69b377cc138f75027721dac22 (patch) | |
| tree | 732fc94b354a26c08fba9cc9059f9c6c900182be /src/components/widgets/Steps.astro | |
Initial template
Diffstat (limited to 'src/components/widgets/Steps.astro')
| -rw-r--r-- | src/components/widgets/Steps.astro | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/src/components/widgets/Steps.astro b/src/components/widgets/Steps.astro new file mode 100644 index 0000000..3c65bf6 --- /dev/null +++ b/src/components/widgets/Steps.astro @@ -0,0 +1,59 @@ +--- +import WidgetWrapper from '~/components/ui/WidgetWrapper.astro'; +import Timeline from '~/components/ui/Timeline.astro'; +import Headline from '~/components/ui/Headline.astro'; +import Image from '~/components/common/Image.astro'; +import type { Steps as Props } from '~/types'; + +const { + title = await Astro.slots.render('title'), + subtitle = await Astro.slots.render('subtitle'), + tagline = await Astro.slots.render('tagline'), + items = [], + image = await Astro.slots.render('image'), + isReversed = false, + + id, + isDark = false, + classes = {}, + bg = await Astro.slots.render('bg'), +} = Astro.props; +--- + +<WidgetWrapper id={id} isDark={isDark} containerClass={`max-w-5xl ${classes?.container ?? ''}`} bg={bg}> + <div class:list={['flex flex-col gap-8 md:gap-12', { 'md:flex-row-reverse': isReversed }, { 'md:flex-row': image }]}> + <div class:list={['md:py-4 md:self-center', { 'md:basis-1/2': image }, { 'w-full': !image }]}> + <Headline + title={title} + subtitle={subtitle} + tagline={tagline} + classes={{ + container: 'text-left rtl:text-right', + title: 'text-3xl lg:text-4xl', + ...((classes?.headline as object) ?? {}), + }} + /> + <Timeline items={items} classes={classes?.items as Record<string, never>} /> + </div> + { + image && ( + <div class="relative md:basis-1/2"> + {typeof image === 'string' ? ( + <Fragment set:html={image} /> + ) : ( + <Image + class="inset-0 object-cover object-top w-full rounded-md shadow-lg md:absolute md:h-full bg-gray-400 dark:bg-slate-700" + widths={[400, 768]} + sizes="(max-width: 768px) 100vw, 432px" + width={432} + height={768} + layout="cover" + src={image?.src} + alt={image?.alt || ''} + /> + )} + </div> + ) + } + </div> +</WidgetWrapper> |
