cult-ui
Display
Animation

texture-card

A well designed card with numorphic undertones.

card
text

Source Code

Files
texture-card
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}