diff --git a/V b/V new file mode 100644 index 0000000000..89540066e7 --- /dev/null +++ b/V @@ -0,0 +1,97 @@ +"use client" + +import { useState, useEffect } from "react" +import { Heart, Share2 } from "lucide-react" +import confetti from "canvas-confetti" + +export default function ValentinePage() { + const [showMessage, setShowMessage] = useState(false) + const [answer, setAnswer] = useState(null) + + useEffect(() => { + const timer = setTimeout(() => setShowMessage(true), 1000) + return () => clearTimeout(timer) + }, []) + + const handleAnswer = (response: "yes" | "no") => { + setAnswer(response) + if (response === "yes") { + confetti({ + particleCount: 100, + spread: 70, + origin: { y: 0.6 }, + }) + } + } + + const shareLink = () => { + if (navigator.share) { + navigator + .share({ + title: "¿Quieres ser mi San Valentín?", + url: window.location.href, + }) + .then(() => { + console.log("Gracias por compartir!") + }) + .catch(console.error) + } else { + // Fallback para navegadores que no soportan Web Share API +// Check for clipboard permissions first +if (navigator.clipboard) { + navigator.permissions.query({ name: 'clipboard-write' as PermissionName }).then(result => { + if (result.state === 'granted' || result.state === 'prompt') { + navigator.clipboard.writeText(window.location.href) + .then(() => alert("Enlace copiado al portapapeles!")) + .catch(() => alert("No se pudo copiar el enlace. Intente de nuevo.")) + } else { + alert("No tiene permisos para usar el portapapeles.") + } + }) +} else { + alert("Su navegador no soporta esta función.") +} + } + + return ( +
+
+

Mi princesa hermosa Amarantha Perez

+
¿Quieres ser mi San Valentín?
+
+ + + +
+ {answer === null ? ( +
+ + +
+ ) : ( +
+ {answer === "yes" ? "¡Qué felicidad! ¡Te amo! ❤️" : "Oh, está bien. Quizás la próxima vez. 😢"} +
+ )} +
+ +
+ ) +} + +