A well designed card with numorphic undertones.
1"use client"
2
3import { ArrowRight, Merge } from "lucide-react"
4
5import { Input } from "@/components/ui/input"
6import { Label } from "@/components/ui/label"
7import { TextureButton } from "@/components/ui/texture-button"
8import {
9 TextureCardContent,
10 TextureCardFooter,
11 TextureCardHeader,
12 TextureCardStyled,
13 TextureCardTitle,
14 TextureSeparator,
15} from "@/components/ui/texture-card"
16
17export function TextureCardDemo() {
18 return (
19 <div className="flex items-center justify-center py-4">
20 <div className="dark:bg-stone-950 h-full rounded-md">
21 <div className=" items-start justify-center gap-6 rounded-lg p-2 md:p-8 grid grid-cols-1 ">
22 <div className="col-span-1 grid items-start gap-6 lg:col-span-1">
23 <div>
24 <TextureCardStyled>
25 <TextureCardHeader className="flex flex-col gap-1 items-center justify-center p-4">
26 <div className="p-3 bg-neutral-950 rounded-full mb-3">
27 <Merge className="h-7 w-7 stroke-neutral-200" />
28 </div>
29 <TextureCardTitle>Create your account</TextureCardTitle>
30 <p className="text-center">
31 Welcome! Please fill in the details to get started.
32 </p>
33 </TextureCardHeader>
34 <TextureSeparator />
35 <TextureCardContent>
36 <div className="flex justify-center gap-2 mb-4">
37 <TextureButton variant="icon">
38 {/* Google Icon */}
39 <svg
40 width="256"
41 height="262"
42 viewBox="0 0 256 262"
43 xmlns="http://www.w3.org/2000/svg"
44 preserveAspectRatio="xMidYMid"
45 className="h-5 w-5"
46 >
47 <path
48 d="M255.878 133.451c0-10.734-.871-18.567-2.756-26.69H130.55v48.448h71.947c-1.45 12.04-9.283 30.172-26.69 42.356l-.244 1.622 38.755 30.023 2.685.268c24.659-22.774 38.875-56.282 38.875-96.027"
49 fill="#4285F4"
50 />
51 <path
52 d="M130.55 261.1c35.248 0 64.839-11.605 86.453-31.622l-41.196-31.913c-11.024 7.688-25.82 13.055-45.257 13.055-34.523 0-63.824-22.773-74.269-54.25l-1.531.13-40.298 31.187-.527 1.465C35.393 231.798 79.49 261.1 130.55 261.1"
53 fill="#34A853"
54 />
55 <path
56 d="M56.281 156.37c-2.756-8.123-4.351-16.827-4.351-25.82 0-8.994 1.595-17.697 4.206-25.82l-.073-1.73L15.26 71.312l-1.335.635C5.077 89.644 0 109.517 0 130.55s5.077 40.905 13.925 58.602l42.356-32.782"
57 fill="#FBBC05"
58 />
59 <path
60 d="M130.55 50.479c24.514 0 41.05 10.589 50.479 19.438l36.844-35.974C195.245 12.91 165.798 0 130.55 0 79.49 0 35.393 29.301 13.925 71.947l42.211 32.783c10.59-31.477 39.891-54.251 74.414-54.251"
61 fill="#EB4335"
62 />
63 </svg>
64 <span className="pl-2">Google</span>
65 </TextureButton>
66 <TextureButton variant="icon">
67 {/* GithubIcon */}
68 <svg
69 viewBox="0 0 256 250"
70 width="256"
71 height="250"
72 fill="currentColor"
73 xmlns="http://www.w3.org/2000/svg"
74 preserveAspectRatio="xMidYMid"
75 className="h-5 w-5"
76 >
77 <path
78 d="M128.001 0C57.317 0 0 57.307 0 128.001c0 56.554 36.676 104.535 87.535 121.46 6.397 1.185 8.746-2.777 8.746-6.158 0-3.052-.12-13.135-.174-23.83-35.61 7.742-43.124-15.103-43.124-15.103-5.823-14.795-14.213-18.73-14.213-18.73-11.613-7.944.876-7.78.876-7.78 12.853.902 19.621 13.19 19.621 13.19 11.417 19.568 29.945 13.911 37.249 10.64 1.149-8.272 4.466-13.92 8.127-17.116-28.431-3.236-58.318-14.212-58.318-63.258 0-13.975 5-25.394 13.188-34.358-1.329-3.224-5.71-16.242 1.24-33.874 0 0 10.749-3.44 35.21 13.121 10.21-2.836 21.16-4.258 32.038-4.307 10.878.049 21.837 1.47 32.066 4.307 24.431-16.56 35.165-13.12 35.165-13.12 6.967 17.63 2.584 30.65 1.255 33.873 8.207 8.964 13.173 20.383 13.173 34.358 0 49.163-29.944 59.988-58.447 63.157 4.591 3.972 8.682 11.762 8.682 23.704 0 17.126-.148 30.91-.148 35.126 0 3.407 2.304 7.398 8.792 6.14C219.37 232.5 256 184.537 256 128.002 256 57.307 198.691 0 128.001 0Zm-80.06 182.34c-.282.636-1.283.827-2.194.39-.929-.417-1.45-1.284-1.15-1.922.276-.655 1.279-.838 2.205-.399.93.418 1.46 1.293 1.139 1.931Zm6.296 5.618c-.61.566-1.804.303-2.614-.591-.837-.892-.994-2.086-.375-2.66.63-.566 1.787-.301 2.626.591.838.903 1 2.088.363 2.66Zm4.32 7.188c-.785.545-2.067.034-2.86-1.104-.784-1.138-.784-2.503.017-3.05.795-.547 2.058-.055 2.861 1.075.782 1.157.782 2.522-.019 3.08Zm7.304 8.325c-.701.774-2.196.566-3.29-.49-1.119-1.032-1.43-2.496-.726-3.27.71-.776 2.213-.558 3.315.49 1.11 1.03 1.45 2.505.701 3.27Zm9.442 2.81c-.31 1.003-1.75 1.459-3.199 1.033-1.448-.439-2.395-1.613-2.103-2.626.301-1.01 1.747-1.484 3.207-1.028 1.446.436 2.396 1.602 2.095 2.622Zm10.744 1.193c.036 1.055-1.193 1.93-2.715 1.95-1.53.034-2.769-.82-2.786-1.86 0-1.065 1.202-1.932 2.733-1.958 1.522-.03 2.768.818 2.768 1.868Zm10.555-.405c.182 1.03-.875 2.088-2.387 2.37-1.485.271-2.861-.365-3.05-1.386-.184-1.056.893-2.114 2.376-2.387 1.514-.263 2.868.356 3.061 1.403Z"
79 fill="#545454"
80 />
81 </svg>
82 <span className="pl-2">Github</span>
83 </TextureButton>
84 </div>
85 <div className="text-center text-sm mb-4">or</div>
86
87 <form className="flex flex-col gap-6">
88 <div className="flex justify-between gap-2">
89 <div>
90 <Label htmlFor="first">First name</Label>
91 <Input
92 id="first"
93 type="first"
94 required
95 className="w-full px-4 py-2 rounded-md border border-neutral-300 dark:border-neutral-700 bg-white/80 dark:bg-neutral-800/80 placeholder-neutral-400 dark:placeholder-neutral-500"
96 />
97 </div>
98 <div>
99 <Label htmlFor="last">Last Name</Label>
100 <Input
101 id="last"
102 type="last"
103 required
104 className="w-full px-4 py-2 rounded-md border border-neutral-300 dark:border-neutral-700 bg-white/80 dark:bg-neutral-800/80 placeholder-neutral-400 dark:placeholder-neutral-500"
105 />
106 </div>
107 </div>
108
109 <div>
110 <Label htmlFor="username">Username</Label>
111 <Input
112 id="username"
113 type="username"
114 required
115 className="w-full px-4 py-2 rounded-md border border-neutral-300 dark:border-neutral-700 bg-white/80 dark:bg-neutral-800/80 placeholder-neutral-400 dark:placeholder-neutral-500"
116 />
117 </div>
118 <div>
119 <Label htmlFor="email">Email</Label>
120 <Input
121 id="email"
122 type="email"
123 required
124 className="w-full px-4 py-2 rounded-md border border-neutral-300 dark:border-neutral-700 bg-white/80 dark:bg-neutral-800/80 placeholder-neutral-400 dark:placeholder-neutral-500"
125 />
126 </div>
127 <div>
128 <Label htmlFor="password">Password</Label>
129 <Input
130 id="password"
131 type="password"
132 required
133 className="w-full px-4 py-2 rounded-md border border-neutral-300 dark:border-neutral-700 bg-white/80 dark:bg-neutral-800/80 placeholder-neutral-400 dark:placeholder-neutral-500"
134 />
135 </div>
136 </form>
137 </TextureCardContent>
138 <TextureSeparator />
139 <TextureCardFooter className="border-b rounded-b-sm">
140 <TextureButton variant="accent" className="w-full">
141 <div className="flex gap-1 items-center justify-center">
142 Continue
143 <ArrowRight className="h-4 w-4 text-neutral-50 mt-[1px]" />
144 </div>
145 </TextureButton>
146 </TextureCardFooter>
147
148 <div className="dark:bg-neutral-800 bg-stone-100 pt-px rounded-b-[20px] overflow-hidden ">
149 <div className="flex flex-col items-center justify-center">
150 <div className="py-2 px-2">
151 <div className="text-center text-sm">
152 Already have an account?{" "}
153 <span className="text-primary">Sign in</span>
154 </div>
155 </div>
156 </div>
157 <TextureSeparator />
158 <div className="flex flex-col items-center justify-center ">
159 <div className="py-2 px-2">
160 <div className="text-center text-xs ">
161 Secured by Supabase
162 </div>
163 </div>
164 </div>
165 </div>
166 </TextureCardStyled>
167 </div>
168 </div>
169 </div>
170 </div>
171 </div>
172 )
173}