Layout 401



import { Button } from "@relume_io/relume-ui";
import type { ButtonProps } from "@relume_io/relume-ui";
import { RxChevronRight } from "react-icons/rx";
type ImageProps = {
src: string;
alt?: string;
};
type FeatureSection = {
icon: ImageProps;
heading: string;
description: string;
button: ButtonProps;
};
type Props = {
tagline: string;
heading: string;
description: string;
featureSections: FeatureSection[];
};
export type Layout401Props = React.ComponentPropsWithoutRef<"section"> & Partial<Props>;
export const Layout401 = (props: Layout401Props) => {
const { tagline, heading, description, featureSections } = {
...Layout401Defaults,
...props,
};
return (
<section id="relume" className="px-[5%] py-16 md:py-24 lg:py-28">
<div className="container">
<div className="mb-12 md:mb-18 lg:mb-20">
<div className="mx-auto max-w-lg text-center">
<p className="mb-3 font-semibold md:mb-4">{tagline}</p>
<h1 className="mb-5 text-5xl font-bold md:mb-6 md:text-7xl lg:text-8xl">{heading}</h1>
<p className="md:text-md">{description}</p>
</div>
</div>
<div className="grid auto-cols-fr grid-cols-1 gap-6 sm:grid-cols-2 md:gap-8 lg:grid-cols-4">
{featureSections.map((feature, index) => (
<FeatureSection key={index} {...feature} />
))}
</div>
</div>
</section>
);
};
const FeatureSection = (featureSection: FeatureSection) => {
return (
<div className="flex flex-col justify-center border border-border-primary p-6">
<div className="mb-3 md:mb-4">
<img src={featureSection.icon.src} className="size-12" alt={featureSection.icon.alt} />
</div>
<h3 className="mb-2 text-lg font-bold leading-[1.4] md:text-2xl">{featureSection.heading}</h3>
<p>{featureSection.description}</p>
<div className="mt-5 md:mt-6">
<Button {...featureSection.button}>{featureSection.button.title}</Button>
</div>
</div>
);
};
export const Layout401Defaults: Props = {
tagline: "Tagline",
heading: "Short heading goes here",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit.",
featureSections: [
{
icon: {
src: "https://d22po4pjz3o32e.cloudfront.net/relume-icon.svg",
alt: "Relume logo 1",
},
heading: "Medium length section heading goes here",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit.",
button: {
title: "Button",
variant: "link",
size: "link",
iconRight: <RxChevronRight />,
},
},
{
icon: {
src: "https://d22po4pjz3o32e.cloudfront.net/relume-icon.svg",
alt: "Relume logo 2",
},
heading: "Medium length section heading goes here",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit.",
button: {
title: "Button",
variant: "link",
size: "link",
iconRight: <RxChevronRight />,
},
},
{
icon: {
src: "https://d22po4pjz3o32e.cloudfront.net/relume-icon.svg",
alt: "Relume logo 3",
},
heading: "Medium length section heading goes here",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit.",
button: {
title: "Button",
variant: "link",
size: "link",
iconRight: <RxChevronRight />,
},
},
{
icon: {
src: "https://d22po4pjz3o32e.cloudfront.net/relume-icon.svg",
alt: "Relume logo 4",
},
heading: "Medium length section heading goes here",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit.",
button: {
title: "Button",
variant: "link",
size: "link",
iconRight: <RxChevronRight />,
},
},
],
};
Need help?
For installation guidelines and API information, visit the docs.
Examples
No items found.