"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 HeaderTab from "./HeaderTab"; const HomeHeader = memo(() => { const pathname = usePathname(); // Schema markup for site navigation (home page specific) const schemaData = { "@context": "https://schema.org", "@type": "WebSite", name: "CommunityRule", url: "https://communityrule.com", description: "Build operating manuals for successful communities", potentialAction: { "@type": "SearchAction", target: "https://communityrule.com/search?q={search_term_string}", "query-input": "required name=search_term_string", }, }; const navigationItems = [ { href: "#", text: "Use cases", extraPadding: true }, { href: "/learn", text: "Learn" }, { href: "#", text: "About" }, ]; const avatarImages = [ { src: "/assets/Avatar_1.png", alt: "Avatar 1" }, { src: "/assets/Avatar_2.png", alt: "Avatar 2" }, { src: "/assets/Avatar_3.png", alt: "Avatar 3" }, ]; const logoConfig = [ { breakpoint: "block sm:hidden", size: "homeHeaderXsmall" as const, showText: false, }, { breakpoint: "hidden sm:block md:hidden", size: "homeHeaderSm" as const, showText: true, }, { breakpoint: "hidden md:block lg:hidden", size: "homeHeaderMd" as const, showText: true, }, { breakpoint: "hidden lg:block xl:hidden", size: "homeHeaderLg" as const, showText: true, }, { breakpoint: "hidden xl:block", size: "homeHeaderXl" as const, showText: true, }, ]; const renderNavigationItems = (size: string) => { 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: string) => { return ( Log in ); }; const renderCreateRuleButton = ( buttonSize: string, 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 ( <>