import { m } from "framer-motion"; import { ReactElement, useEffect, useState } from "react"; import HomeLayout from "../layouts/HomeLayout"; import { homeMain } from "../layouts/NavTemplates"; import Image from "next/image"; import Head from "next/head"; function Home() { const [emotesUrls, setEmotes] = useState([]); const [currentEmote, setCurrentEmote] = useState(0); useEffect(() => { fetch("/api/emotes") .then((res) => res.json()) .then((data) => { // if error, return if (data.error) { return; } // get all emote URLs let emoteUrls = data["7tv"].channel.map((emote: any) => { let base_url = emote.data.host.url; // get the largest emote size, append it to the base url let largest = emote.data.host.files[emote.data.host.files.length - 1]; // if width != height, skip it if (largest.width !== largest.height) { return null; } return `https:${base_url}/${largest.name}`; }); // remove null values emoteUrls = emoteUrls.filter((emote: any) => emote !== null); setEmotes(emoteUrls); setCurrentEmote(Math.floor(Math.random() * emoteUrls.length)); }); // eslint-disable-next-line react-hooks/exhaustive-deps }, []); // change emote every 5 seconds, separated from the fetch call so it only initializes once when the emotes are loaded useEffect(() => { const interval = setInterval(() => { // choose a random emote let randomEmote = Math.floor(Math.random() * emotesUrls.length); setCurrentEmote(randomEmote); }, 5000); return () => clearInterval(interval); }, [emotesUrls]); // until the emotes are loaded, show the logo as a placeholder let slideShow = ( toffee Logo ); // if the emotes are loaded, show the slideshow if (emotesUrls.length > 0) { slideShow = ( 7tv emote ); } return ( <> Home - toffee
t off ee
a tax-free offline emote exchange utility
{slideShow} currently in development!
); } const sloganContainerVariants = { initial: { opacity: 0, y: -100, }, animate: { opacity: 1, y: 0, transition: { delay: 0.5, duration: 2.5, type: "spring", bounce: 0.5, stiffness: 150, delayChildren: 1.0, staggerChildren: 0.1, }, }, }; const sloganHeaderVariants = { initial: { opacity: 0, y: -15, }, animate: { opacity: 1, y: 0, }, }; const sloganSecondaryContainerVariants = { initial: { opacity: 0, rotate: 0, }, animate: { opacity: 1, rotate: -15, transition: { delay: 3.5, duration: 1.0, }, }, }; const sloganSecondaryVariants = { animate: { fontSize: ["1.5rem", "1.575rem", "1.5rem"], transition: { duration: 0.5, repeat: Infinity, }, }, }; const slideShowVariants = { initial: { opacity: 0, }, animate: { opacity: 1, transition: { delay: 2.0, duration: 1.0, }, }, }; // set the layout for the page, this is used to wrap the page in a layout Home.getLayout = function getLayout(page: ReactElement) { return {page}; }; export default Home;