login-2

PreviousNext

A Card component with optional code display for UI blocks.

Docs
tailwind-admincomponent

Preview

Loading preview…
app/components/ui-blocks/cards/code/LoginFormTwoCode.tsx
import { cn } from "@/lib/utils"
import { Button } from "@/components/ui/button"
import {
    Field,
    FieldDescription,
    FieldGroup,
    FieldLabel,
    FieldSeparator,
} from "@/components/ui/field"
import { Input } from "@/components/ui/input"
import Image from "next/image"
import Link from "next/link"

export default function LoginForm({
    className,
    ...props
}: React.ComponentProps<"form">) {
    return (
        <section>
            <div>
                <div className='p-6'>
                    <div className="grid min-h-svh lg:grid-cols-2">
                        <div className="flex flex-col gap-4 p-6 md:p-10">
                            <div className="flex justify-center gap-2 md:justify-start">
                                <Link href={"/"}>
                                    <Image src={"https://tailwind-admin.com/images/logo/white-logo.svg"} alt="Tailwindadmin white logo" width={200} height={40} className="dark:block hidden" />
                                </Link>
                            </div>
                            <div className="flex flex-1 items-center justify-center">
                                <div className="w-full max-w-xs">
                                    <form className={cn("flex flex-col gap-6", className)} {...props}>
                                        <FieldGroup>
                                            <div className="flex flex-col items-center gap-1 text-center">
                                                <h1 className="text-2xl font-bold">Login to your account</h1>
                                                <p className="text-muted-foreground text-sm text-balance">
                                                    Enter your email below to login to your account
                                                </p>
                                            </div>
                                            <Field>
                                                <FieldLabel htmlFor="email">Email</FieldLabel>
                                                <Input id="email" type="email" placeholder="m@example.com" required />
                                            </Field>
                                            <Field>
                                                <div className="flex items-center">
                                                    <FieldLabel htmlFor="password">Password</FieldLabel>
                                                    <Link
                                                        href="#"
                                                        className="ml-auto text-sm underline-offset-4 hover:underline"
                                                    >
                                                        Forgot your password?
                                                    </Link>
                                                </div>
                                                <Input id="password" type="password" required />
                                            </Field>
                                            <Field>
                                                <Button type="submit">Login</Button>
                                            </Field>
                                            <FieldSeparator>Or continue with</FieldSeparator>
                                            <Field>
                                                <Button variant="outline" type="button">
                                                    <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24">
                                                        <path
                                                            d="M12 .297c-6.63 0-12 5.373-12 12 0 5.303 3.438 9.8 8.205 11.385.6.113.82-.258.82-.577 0-.285-.01-1.04-.015-2.04-3.338.724-4.042-1.61-4.042-1.61C4.422 18.07 3.633 17.7 3.633 17.7c-1.087-.744.084-.729.084-.729 1.205.084 1.838 1.236 1.838 1.236 1.07 1.835 2.809 1.305 3.495.998.108-.776.417-1.305.76-1.605-2.665-.3-5.466-1.332-5.466-5.93 0-1.31.465-2.38 1.235-3.22-.135-.303-.54-1.523.105-3.176 0 0 1.005-.322 3.3 1.23.96-.267 1.98-.399 3-.405 1.02.006 2.04.138 3 .405 2.28-1.552 3.285-1.23 3.285-1.23.645 1.653.24 2.873.12 3.176.765.84 1.23 1.91 1.23 3.22 0 4.61-2.805 5.625-5.475 5.92.42.36.81 1.096.81 2.22 0 1.606-.015 2.896-.015 3.286 0 .315.21.69.825.57C20.565 22.092 24 17.592 24 12.297c0-6.627-5.373-12-12-12"
                                                            fill="currentColor"
                                                        />
                                                    </svg>
                                                    Login with GitHub
                                                </Button>
                                                <FieldDescription className="text-center">
                                                    Don&apos;t have an account?{" "}
                                                    <Link href="#" className="underline underline-offset-4">
                                                        Sign up
                                                    </Link>
                                                </FieldDescription>
                                            </Field>
                                        </FieldGroup>
                                    </form>
                                </div>
                            </div>
                        </div>
                        <div className="bg-muted relative hidden lg:flex items-center justify-center ">
                            <Image
                                src="https://tailwind-admin.com/images/login/login-side-image.webp"
                                alt="login-side-image"
                                width={450}
                                height={450}
                            />
                        </div>
                    </div>
                </div>
            </div>
        </section>
    )
}

Installation

npx shadcn@latest add @tailwind-admin/login-2

Usage

import { Login2 } from "@/components/login-2"
<Login2 />