CTA 54



<section id="relume" class="px-[5%] py-16 md:py-24 lg:py-28">
<div class="container relative">
<div class="relative z-10 flex flex-col items-center p-8 md:p-12 lg:p-16">
<div class="max-w-lg text-center">
<h2
class="rb-5 mb-5 text-5xl font-bold text-text-alternative md:mb-6 md:text-7xl lg:text-8xl"
>
Medium length heading goes here
</h2>
<p class="text-text-alternative md:text-md">
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse varius enim in eros
elementum tristique.
</p>
</div>
<div class="mx-auto mt-6 max-w-sm md:mt-8">
<form
class="rb-4 mb-4 grid max-w-sm grid-cols-1 gap-y-3 sm:grid-cols-[1fr_max-content] sm:gap-4"
>
<div class="relative flex w-full items-center">
<input
type="email"
class="flex size-full min-h-11 border border-border-primary bg-background-primary py-2 align-middle file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-neutral focus-visible:outline-none disabled:cursor-not-allowed disabled:opacity-50 px-3"
id="email"
placeholder="Enter your email"
value=""
/>
</div>
<button
class="focus-visible:ring-border-primary inline-flex gap-3 whitespace-nowrap ring-offset-white transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 border border-border-primary bg-background-alternative text-text-alternative items-center justify-center px-6 py-3"
title="Sign up"
>
Sign up
</button>
</form>
<div>
<p class="text-xs text-text-alternative">
By clicking Sign Up you're confirming that you agree with our
<a href="#" class="underline">Terms and Conditions</a>.
</p>
</div>
</div>
</div>
<div class="absolute inset-0 z-0">
<img
src="https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg"
class="size-full object-cover"
alt="Relume placeholder image"
/>
<div class="absolute inset-0 bg-black/50"></div>
</div>
</div>
</section>
"use client";
import { useState } from "react";
import { Button, Input } from "@relume_io/relume-ui";
import type { ButtonProps } from "@relume_io/relume-ui";
type ImageProps = {
src: string;
alt?: string;
};
type Props = {
heading: string;
description: string;
inputPlaceholder?: string;
button: ButtonProps;
termsAndConditions: string;
image: ImageProps;
};
export type Cta54Props = React.ComponentPropsWithoutRef<"section"> & Partial<Props>;
export const Cta54 = (props: Cta54Props) => {
const { heading, description, inputPlaceholder, button, termsAndConditions, image } = {
...Cta54Defaults,
...props,
};
const [emailInput, setEmailInput] = useState<string>("");
const handleSubmit = (event: React.FormEvent<HTMLFormElement>) => {
event.preventDefault();
console.log({
emailInput,
});
};
return (
<section id="relume" className="px-[5%] py-16 md:py-24 lg:py-28">
<div className="container relative">
<div className="relative z-10 flex flex-col items-center p-8 md:p-12 lg:p-16">
<div className="max-w-lg text-center">
<h2 className="rb-5 mb-5 text-5xl font-bold text-text-alternative md:mb-6 md:text-7xl lg:text-8xl">
{heading}
</h2>
<p className="text-text-alternative md:text-md">{description}</p>
</div>
<div className="mx-auto mt-6 max-w-sm md:mt-8">
<form
className="rb-4 mb-4 grid max-w-sm grid-cols-1 gap-y-3 sm:grid-cols-[1fr_max-content] sm:gap-4"
onSubmit={handleSubmit}
>
<Input
id="email"
type="email"
placeholder={inputPlaceholder}
value={emailInput}
onChange={(e) => setEmailInput(e.target.value)}
/>
<Button {...button} className="items-center justify-center px-6 py-3">
{button.title}
</Button>
</form>
<div dangerouslySetInnerHTML={{ __html: termsAndConditions }} />
</div>
</div>
<div className="absolute inset-0 z-0">
<img src={image.src} className="size-full object-cover" alt={image.alt} />
<div className="absolute inset-0 bg-black/50" />
</div>
</div>
</section>
);
};
export const Cta54Defaults: Props = {
heading: "Medium length heading goes here",
description:
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse varius enim in eros elementum tristique.",
inputPlaceholder: "Enter your email",
button: {
title: "Sign up",
variant: "primary",
size: "sm",
},
termsAndConditions: `
<p class='text-xs text-text-alternative'>
By clicking Sign Up you're confirming that you agree with our
<a href='#' class='underline'>Terms and Conditions</a>.
</p>
`,
image: {
src: "https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg",
alt: "Relume placeholder image",
},
};
Need help?
For installation guidelines and API information, visit the docs.
Examples
No items found.