-
Notifications
You must be signed in to change notification settings - Fork 112
/
Copy pathhome-page.tsx
126 lines (121 loc) · 5.24 KB
/
home-page.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
"use client";
import { motion } from "framer-motion";
import { FADE_DOWN_ANIMATION_VARIANTS } from "@/lib/constants";
import Balancer from "react-wrap-balancer";
import { /* ArrowRight */ Images, Upload } from "lucide-react";
import { nFormatter } from "@/lib/utils";
import PhotoBooth from "@/components/home/photo-booth";
import Link from "next/link";
import { Button } from "@/components/ui/button";
import { UploadDialog, useUploadDialog } from "@/components/home/upload-dialog";
import { FAQ } from "@/components/home/faq";
import { useUserDataStore } from "@/components/layout/navbar";
import { useSignInDialog } from "@/components/layout/sign-in-dialog";
import { useCheckoutDialog } from "@/components/layout/checkout-dialog";
import { TermsAndPrivacy } from "@/components/layout/terms-and-privacy";
// import {
// AgePredictDialog,
// useAgePredictDialog,
// } from "@/components/age-predict-modal";
export default function HomePage({ count }: { count: number | null }) {
const setShowUploadModal = useUploadDialog((s) => s.setOpen);
// const setShowAgePredictModal = useAgePredictDialog((s) => s.setOpen);
const setShowCheckoutModal = useCheckoutDialog((s) => s.setOpen);
const setShowSignInModal = useSignInDialog((s) => s.setOpen);
const userData = useUserDataStore((s) => s.userData);
return (
<div className="flex flex-col items-center justify-center">
<UploadDialog />
{/*<AgePredictDialog />*/}
<motion.div
className="z-10 max-w-2xl px-5 xl:px-0"
initial="hidden"
whileInView="show"
animate="show"
viewport={{ once: true }}
variants={{
hidden: {},
show: {
transition: {
staggerChildren: 0.15,
},
},
}}
>
{/*<motion.div*/}
{/* variants={FADE_DOWN_ANIMATION_VARIANTS}*/}
{/* className="mx-auto mb-5 flex max-w-fit items-center justify-center space-x-2 overflow-hidden rounded-full bg-blue-100 px-7 py-2 transition-colors hover:bg-blue-200"*/}
{/* onClick={() => setShowAgePredictModal(true)}*/}
{/*>*/}
{/* <p className="text-sm font-semibold text-[#1d9bf0]">*/}
{/* NEW: Find out how old you look for free*/}
{/* </p>*/}
{/* <ArrowRight className="size-5 text-[#1d9bf0]" />*/}
{/*</motion.div>*/}
<motion.h1
className="bg-gradient-to-br from-black to-stone-500 bg-clip-text text-center font-display text-4xl font-bold tracking-[-0.02em] text-transparent drop-shadow-sm md:text-7xl md:leading-[5rem]"
variants={FADE_DOWN_ANIMATION_VARIANTS}
>
<Balancer>See how well you age with AI</Balancer>
</motion.h1>
<motion.p
className="mt-6 text-center text-gray-500 md:text-xl"
variants={FADE_DOWN_ANIMATION_VARIANTS}
>
<Balancer ratio={0.6}>
Curious how you'll look in 10 years? 20 years? When you're
90 years old? Upload a photo and find out!
</Balancer>
</motion.p>
<motion.div variants={FADE_DOWN_ANIMATION_VARIANTS} className="-mb-4">
<div className="mt-6 flex flex-row justify-center space-x-4">
<Button
className="space-x-2 rounded-full border border-primary transition-colors hover:bg-primary-foreground hover:text-primary"
onClick={() => {
if (!userData) {
setShowSignInModal(true);
} else if (userData.credits < 10) {
setShowCheckoutModal(true);
} else {
setShowUploadModal(true);
}
}}
>
<Upload className="h-5 w-5" />
<p>Upload a Photo</p>
</Button>
<Link href={"/gallery"}>
<Button
className="space-x-2 rounded-full border border-primary transition-colors hover:bg-primary-foreground hover:text-primary"
onClick={(e) => {
if (!userData) {
e.preventDefault();
setShowSignInModal(true);
}
}}
>
<Images className="h-5 w-5" />
<p>My Gallery</p>
</Button>
</Link>
</div>
<p className="mt-2 text-center text-sm text-gray-500">
{count && count > 0
? `${nFormatter(370986 + count)} photos generated and counting!`
: "Generate your photo now!"}
</p>
</motion.div>
<PhotoBooth
input={`${process.env.NEXT_PUBLIC_SUPABASE_URL}/storage/v1/object/public/temp/input.jpeg`}
// input="https://images.extrapolate.workers.dev/input.jpg"
// blurDataURL=""
output={`${process.env.NEXT_PUBLIC_SUPABASE_URL}/storage/v1/object/public/temp/output.gif`}
// output="https://images.extrapolate.workers.dev/output.gif"
className="h-[350px] sm:h-[600px] sm:w-[600px]"
/>
</motion.div>
<FAQ />
<TermsAndPrivacy/>
</div>
);
}