nextui/apps/docs/components/marketing/customization.tsx
WK 8c2613713a
refactor: migrate eslint to v9 (#5267)
* refactor: migrate eslint to v9

* chore: lint

* chore: update eslint command

* chore: fix lint warnings

* chore: separate lint and lint:fix

* chore: exclude contentlayer generated code

* fix(scripts): add missing await
2025-06-01 13:51:30 -03:00

72 lines
2.3 KiB
TypeScript

"use client";
import {Button, Link} from "@heroui/react";
import NextLink from "next/link";
import {title, subtitle, titleWrapper, sectionWrapper} from "@/components/primitives";
import {CodeWindow} from "@/components/code-window";
import landingContent from "@/content/landing";
import {GradientBox} from "@/components/gradient-box";
import {CustomButton} from "@/components/demos";
export const Customization = () => {
return (
<section className={sectionWrapper({class: "mt-16 lg:mt-44"})}>
<div className="flex flex-col gap-8">
<div>
<div className={titleWrapper({class: "inline md:block"})}>
<h1 className={title({size: "lg"})}>Customization made</h1>
<div>
<h1 className={title({size: "lg", color: "pink"})}>easy.</h1>
</div>
</div>
<p className={subtitle()}>
HeroUI is based on{" "}
<Link
isExternal
className="text-xl text-default-500 font-light [&>svg]:ml-1"
href="https://tailwind-variants.org"
underline="always"
>
Tailwind Variants
</Link>
, it simplifies component slots customization while avoiding Tailwind class conflicts.
</p>
</div>
<div className="grid grid-cols-1 lg:grid-cols-2 gap-4">
<CodeWindow
showWindowIcons
className="min-h-[320px] h-auto"
language="jsx"
title="custom-button.tsx"
value={landingContent.customizationCode}
/>
<div className="flex flex-col justify-center gap-6">
<GradientBox
isCentered
className="h-full min-h-[320px] py-12 px-8"
color="pink"
to="top-right"
>
<CustomButton />
</GradientBox>
</div>
</div>
<div className="flex w-1/2 justify-start">
<Button
aria-label="Learn more about customization"
as={NextLink}
className="max-w-fit bg-pink-100 text-pink-500 dark:bg-pink-900 dark:text-pink-300"
href="/docs/customization/customize-theme"
radius="full"
size="sm"
variant="flat"
>
Learn more
</Button>
</div>
</div>
</section>
);
};