Footer 8



<footer id="relume" class="px-[5%] py-12 md:py-18 lg:py-20">
<div class="container">
<div
class="grid grid-cols-1 items-start justify-between gap-x-[8vw] gap-y-12 pb-12 sm:gap-y-10 md:gap-y-14 md:pb-18 lg:grid-cols-[1fr_0.5fr] lg:pb-20"
>
<div class="flex flex-col items-start">
<a href="#" class="mb-8"
><img
src="https://d22po4pjz3o32e.cloudfront.net/logo-image.svg"
alt="Logo image"
class="inline-block"
/></a>
<ul
class="grid grid-flow-row grid-cols-1 items-start justify-center justify-items-start gap-y-4 md:grid-flow-col md:grid-cols-[max-content] md:justify-start md:justify-items-start md:gap-x-6"
>
<li class="font-semibold"><a href="#">Link One</a></li>
<li class="font-semibold"><a href="#">Link Two</a></li>
<li class="font-semibold"><a href="#">Link Three</a></li>
<li class="font-semibold"><a href="#">Link Four</a></li>
<li class="font-semibold"><a href="#">Link Five</a></li>
</ul>
</div>
<div class="max-w-md lg:min-w-[25rem]">
<p class="mb-3 font-semibold md:mb-4">Subscribe</p>
<form
class="mb-3 grid grid-cols-1 gap-x-4 gap-y-3 sm:grid-cols-[1fr_max-content] sm:gap-y-4 md: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 items-center justify-center 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 text-text-primary bg-background-primary px-5 py-2"
title="Subscribe"
>
Subscribe
</button>
</form>
<div>
<p class="text-xs">
By subscribing you agree to with our
<a href="#" class="underline">Privacy Policy</a>.
</p>
</div>
</div>
</div>
<div class="h-px w-full bg-black"></div>
<div
class="flex flex-col items-start justify-start pb-4 pt-6 text-sm md:flex-row md:items-center md:justify-between md:pb-0 md:pt-8 md:text-center"
>
<ul
class="grid grid-flow-row grid-cols-[max-content] gap-y-4 text-sm md:grid-flow-col md:gap-x-6 md:gap-y-0 lg:justify-center"
>
<li class="underline decoration-black underline-offset-1">
<a href="#">Privacy Policy</a>
</li>
<li class="underline decoration-black underline-offset-1">
<a href="#">Terms of Service</a>
</li>
<li class="underline decoration-black underline-offset-1">
<a href="#">Cookies Settings</a>
</li>
</ul>
<p class="mt-8 md:mt-0">© 2024 Relume. All rights reserved.</p>
</div>
</div>
</footer>
"use client";
import { Button, Input } from "@relume_io/relume-ui";
import type { ButtonProps } from "@relume_io/relume-ui";
import { useState } from "react";
type ImageProps = {
url?: string;
src: string;
alt?: string;
};
type Links = {
title: string;
url: string;
};
type ColumnLinks = {
links: Links[];
};
type FooterLink = {
title: string;
url: string;
};
type Props = {
logo: ImageProps;
inputPlaceholder?: string;
button: ButtonProps;
termsAndConditions: string;
columnLinks: ColumnLinks[];
footerText: string;
footerLinks: FooterLink[];
};
export type Footer8Props = React.ComponentPropsWithoutRef<"section"> & Partial<Props>;
export const Footer8 = (props: Footer8Props) => {
const {
logo,
inputPlaceholder,
button,
termsAndConditions,
footerText,
columnLinks,
footerLinks,
} = {
...Footer8Defaults,
...props,
};
const [emailInput, setEmailInput] = useState<string>("");
const handleSubmit = (event: React.FormEvent<HTMLFormElement>) => {
event.preventDefault();
console.log({
emailInput,
});
};
return (
<footer id="relume" className="px-[5%] py-12 md:py-18 lg:py-20">
<div className="container">
<div className="grid grid-cols-1 items-start justify-between gap-x-[8vw] gap-y-12 pb-12 sm:gap-y-10 md:gap-y-14 md:pb-18 lg:grid-cols-[1fr_0.5fr] lg:pb-20">
<div className="flex flex-col items-start">
<a href={logo.url} className="mb-8">
<img src={logo.src} alt={logo.alt} className="inline-block" />
</a>
{columnLinks.map((column, index) => (
<ul
key={index}
className="grid grid-flow-row grid-cols-1 items-start justify-center justify-items-start gap-y-4 md:grid-flow-col md:grid-cols-[max-content] md:justify-start md:justify-items-start md:gap-x-6"
>
{column.links.map((link, linkIndex) => (
<li key={linkIndex} className="font-semibold">
<a href={link.url}>{link.title}</a>
</li>
))}
</ul>
))}
</div>
<div className="max-w-md lg:min-w-[25rem]">
<p className="mb-3 font-semibold md:mb-4">Subscribe</p>
<form
className="mb-3 grid grid-cols-1 gap-x-4 gap-y-3 sm:grid-cols-[1fr_max-content] sm:gap-y-4 md:gap-4"
onSubmit={handleSubmit}
>
<Input
id="email"
type="email"
placeholder={inputPlaceholder}
value={emailInput}
onChange={(e) => setEmailInput(e.target.value)}
/>
<Button {...button}>{button.title}</Button>
</form>
<div dangerouslySetInnerHTML={{ __html: termsAndConditions }} />
</div>
</div>
<div className="h-px w-full bg-black" />
<div className="flex flex-col items-start justify-start pb-4 pt-6 text-sm md:flex-row md:items-center md:justify-between md:pb-0 md:pt-8 md:text-center">
<ul className="grid grid-flow-row grid-cols-[max-content] gap-y-4 text-sm md:grid-flow-col md:gap-x-6 md:gap-y-0 lg:justify-center">
{footerLinks.map((link, index) => (
<li key={index} className="underline decoration-black underline-offset-1">
<a href={link.url}>{link.title}</a>
</li>
))}
</ul>
<p className="mt-8 md:mt-0">{footerText}</p>
</div>
</div>
</footer>
);
};
export const Footer8Defaults: Props = {
logo: {
url: "#",
src: "https://d22po4pjz3o32e.cloudfront.net/logo-image.svg",
alt: "Logo image",
},
inputPlaceholder: "Enter your email",
button: {
title: "Subscribe",
variant: "secondary",
size: "sm",
},
termsAndConditions: `
<p class='text-xs'>
By subscribing you agree to with our
<a href='#' class='underline'>Privacy Policy</a>.
</p>
`,
columnLinks: [
{
links: [
{ title: "Link One", url: "#" },
{ title: "Link Two", url: "#" },
{ title: "Link Three", url: "#" },
{ title: "Link Four", url: "#" },
{ title: "Link Five", url: "#" },
],
},
],
footerText: "© 2024 Relume. All rights reserved.",
footerLinks: [
{ title: "Privacy Policy", url: "#" },
{ title: "Terms of Service", url: "#" },
{ title: "Cookies Settings", url: "#" },
],
};
Need help?
For installation guidelines and API information, visit the docs.