import { m } from "framer-motion"; import { ReactElement, useEffect, useState } from "react"; import HomeLayout from "../layouts/HomeLayout"; import { homeMain } from "../layouts/NavTemplates"; import type { NextPageWithLayout } from "./_app"; import Image from "next/image"; import Head from "next/head"; const Home: NextPageWithLayout = () => { let api7tvEmotes = `/api/7tv/emotes?c=61ad997effa9aba101bcfddf`; const [emotesUrls, setEmotes] = useState([]); const [currentEmote, setCurrentEmote] = useState(0); useEffect(() => { fetch(api7tvEmotes) .then((res) => res.json()) .then((data) => { // get all emote URLs let emoteUrls = data.channel.user.emote_sets[0].emotes.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)); }); console.log(currentEmote); // 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 = ( InvestBot Logo ); // if the emotes are loaded, show the slideshow if (emotesUrls.length > 0) { slideShow = ( 7tv emote ); } return ( <> Home - InvestBot

Buy high

Sell low

...or something like that
{slideShow}
); }; 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: 0.5, staggerChildren: 1.0, }, }, }; const sloganHeaderVariants = { initial: { opacity: 0, }, animate: { opacity: 1, }, }; const sloganSecondaryVariants = { initial: { opacity: 0, }, animate: { opacity: 1, transition: { delay: 3.5, }, }, }; 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;