diff --git a/frontend/src/components/gdpr/gdprbanner.tsx b/frontend/src/components/gdpr/gdprbanner.tsx index 445cc90e..5a3313f8 100644 --- a/frontend/src/components/gdpr/gdprbanner.tsx +++ b/frontend/src/components/gdpr/gdprbanner.tsx @@ -81,7 +81,7 @@ const GDPRBanner: React.FC = () => { )} {showOptOutForm && ( -
+
Please select which services you would like to opt out of.
diff --git a/frontend/src/components/listing/ListingImageFlipper.tsx b/frontend/src/components/listing/ListingImageFlipper.tsx index 2d5180f0..890c82b8 100644 --- a/frontend/src/components/listing/ListingImageFlipper.tsx +++ b/frontend/src/components/listing/ListingImageFlipper.tsx @@ -1,4 +1,4 @@ -import { useState } from "react"; +import { useMemo, useState } from "react"; import { FaChevronLeft, FaChevronRight, FaTimes } from "react-icons/fa"; import placeholder from "@/components/listing/pics/placeholder.jpg"; @@ -15,7 +15,27 @@ const ListingImageFlipper = (props: Props) => { const { artifacts, name, currentImageIndex, setCurrentImageIndex } = props; const [isFullScreen, setIsFullScreen] = useState(false); - if (artifacts.length === 0) { + const imageArtifacts = useMemo( + () => + artifacts + .map((artifact, index) => ({ artifact, originalIndex: index })) + .filter(({ artifact }) => artifact.artifact_type === "image") + .map(({ artifact, originalIndex }, newIndex) => ({ + artifact, + originalIndex, + newIndex, + })), + [artifacts], + ); + + const currentImageArrayIndex = useMemo(() => { + const found = imageArtifacts.findIndex( + ({ originalIndex }) => originalIndex === currentImageIndex, + ); + return found >= 0 ? found : 0; + }, [imageArtifacts, currentImageIndex]); + + if (imageArtifacts.length === 0) { return (
@@ -29,7 +49,18 @@ const ListingImageFlipper = (props: Props) => { ); } - const currentArtifact = artifacts[currentImageIndex]; + const handleNavigate = (direction: "next" | "prev") => { + const nextIndex = + direction === "next" + ? (currentImageArrayIndex + 1) % imageArtifacts.length + : currentImageArrayIndex === 0 + ? imageArtifacts.length - 1 + : currentImageArrayIndex - 1; + + setCurrentImageIndex(imageArtifacts[nextIndex].originalIndex); + }; + + const currentArtifact = imageArtifacts[currentImageArrayIndex].artifact; return ( <> @@ -41,24 +72,16 @@ const ListingImageFlipper = (props: Props) => { className="cursor-zoom-in rounded-lg w-[500px]" /> {/* Navigation arrows */} - {artifacts.length > 1 && ( + {imageArtifacts.length > 1 && ( <> + ); + } + + return ( + + ); +}; diff --git a/frontend/src/components/nav/Navbar.tsx b/frontend/src/components/nav/Navbar.tsx index 71b52a57..3fc63eee 100644 --- a/frontend/src/components/nav/Navbar.tsx +++ b/frontend/src/components/nav/Navbar.tsx @@ -1,5 +1,4 @@ import { useState } from "react"; -import { FaExternalLinkAlt } from "react-icons/fa"; import { FaBars } from "react-icons/fa6"; import { Link, useLocation, useNavigate } from "react-router-dom"; @@ -10,6 +9,8 @@ import { Button } from "@/components/ui/button"; import { useAuthentication } from "@/hooks/useAuth"; import ROUTES from "@/lib/types/routes"; +import { NavButton } from "./NavButton"; + const Navbar = () => { const { isAuthenticated } = useAuthentication(); const [showSidebar, setShowSidebar] = useState(false); @@ -57,8 +58,24 @@ const Navbar = () => { onClick={() => handleFeaturedClick(listing.username, listing.slug) } - variant="outline" - className="px-2 xl:px-3 py-2 text-sm tracking-widest text-gray-1" + variant={ + location.pathname === + ROUTES.BOT.buildPath({ + username: listing.username, + slug: listing.slug || "", + }) + ? "ghost" + : "outline" + } + className={`px-2 xl:px-3 py-2 text-sm tracking-widest text-gray-1 ${ + location.pathname === + ROUTES.BOT.buildPath({ + username: listing.username, + slug: listing.slug || "", + }) + ? "underline underline-offset-4 decoration-2" + : "" + }`} > {listing.name} @@ -66,72 +83,55 @@ const Navbar = () => {
{navItems.map((item) => item.isExternal ? ( - + {item.name} + ) : ( - + {item.name} + ), )}
{isAuthenticated ? ( <> - - + Logout + ) : ( <> - - + Sign Up + )}
diff --git a/frontend/src/components/nav/Sidebar.tsx b/frontend/src/components/nav/Sidebar.tsx index 739b9262..80ef79e4 100644 --- a/frontend/src/components/nav/Sidebar.tsx +++ b/frontend/src/components/nav/Sidebar.tsx @@ -28,7 +28,7 @@ const SidebarItem = ({