"use client"; import React, { memo } from "react"; import { usePathname } from "next/navigation"; import Logo from "./Logo"; import MenuBar from "./MenuBar"; import MenuBarItem from "./MenuBarItem"; import Button from "./Button"; import AvatarContainer from "./AvatarContainer"; import Avatar from "./Avatar"; import { getAssetPath, ASSETS } from "../../lib/assetUtils"; // Configuration data for testing export const navigationItems = [ { href: "#", text: "Use cases", extraPadding: true }, { href: "/learn", text: "Learn" }, { href: "#", text: "About" }, ]; export const avatarImages = [ { src: getAssetPath(ASSETS.AVATAR_1), alt: "Avatar 1" }, { src: getAssetPath(ASSETS.AVATAR_2), alt: "Avatar 2" }, { src: getAssetPath(ASSETS.AVATAR_3), alt: "Avatar 3" }, ]; export const logoConfig = [ { breakpoint: "block sm:hidden", size: "header" as const, showText: false }, { breakpoint: "hidden sm:block md:hidden", size: "header" as const, showText: true, }, { breakpoint: "hidden md:block lg:hidden", size: "headerMd" as const, showText: true, }, { breakpoint: "hidden lg:block xl:hidden", size: "headerLg" as const, showText: true, }, { breakpoint: "hidden xl:block", size: "headerXl" as const, showText: true }, ]; const Header = memo(() => { const pathname = usePathname(); // Schema markup for site navigation const schemaData = { "@context": "https://schema.org", "@type": "WebSite", name: "CommunityRule", url: "https://communityrule.com", potentialAction: { "@type": "SearchAction", target: "https://communityrule.com/search?q={search_term_string}", "query-input": "required name=search_term_string", }, }; type NavSize = | "default" | "xsmall" | "xsmallUseCases" | "home" | "homeMd" | "homeUseCases" | "large" | "largeUseCases" | "homeXlarge" | "xlarge"; const renderNavigationItems = (size: NavSize) => { return navigationItems.map((item, index) => ( {item.text} )); }; const renderAvatarGroup = ( containerSize: "small" | "medium" | "large" | "xlarge", avatarSize: "small" | "medium" | "large" | "xlarge", ) => { return ( {avatarImages.map((avatar, index) => ( ))} ); }; const renderLoginButton = (size: NavSize) => { return ( Log in ); }; const renderCreateRuleButton = ( buttonSize: "xsmall" | "small" | "medium" | "large" | "xlarge", containerSize: "small" | "medium" | "large" | "xlarge", avatarSize: "small" | "medium" | "large" | "xlarge", ) => { return ( ); }; const renderLogo = ( size: | "default" | "homeHeaderXsmall" | "homeHeaderSm" | "homeHeaderMd" | "homeHeaderLg" | "homeHeaderXl" | "header" | "headerMd" | "headerLg" | "headerXl" | "footer" | "footerLg", showText: boolean, ) => { return ; }; return ( <>