diff --git a/packages/nextjs/components/Header.tsx b/packages/nextjs/components/Header.tsx index a4669f5a3..cd6966a0b 100644 --- a/packages/nextjs/components/Header.tsx +++ b/packages/nextjs/components/Header.tsx @@ -1,38 +1,11 @@ import React, { useCallback, useRef, useState } from "react"; import Image from "next/image"; import Link from "next/link"; -import { useRouter } from "next/router"; import { Bars3Icon } from "@heroicons/react/24/outline"; -import { headerMenuLinks } from "~~/components/headerMenuLinks"; +import { HeaderMenuLinks } from "~~/components/HeaderMenuLinks"; import { FaucetButton, RainbowKitCustomConnectButton } from "~~/components/scaffold-eth"; import { useOutsideClick } from "~~/hooks/scaffold-eth"; -const NavLink = ({ href, children }: { href: string; children: React.ReactNode }) => { - const router = useRouter(); - const isActive = router.pathname === href; - - return ( - - {children} - - ); -}; - -const navLinks = headerMenuLinks.map(({ label, href, icon }) => ( -
  • - - {icon} - {label} - -
  • -)); - /** * Site header */ @@ -65,7 +38,7 @@ export const Header = () => { setIsDrawerOpen(false); }} > - {navLinks} + )} @@ -78,7 +51,9 @@ export const Header = () => { Ethereum dev stack - +
    diff --git a/packages/nextjs/components/HeaderMenuLinks.tsx b/packages/nextjs/components/HeaderMenuLinks.tsx new file mode 100644 index 000000000..7a0857a8a --- /dev/null +++ b/packages/nextjs/components/HeaderMenuLinks.tsx @@ -0,0 +1,58 @@ +import React from "react"; +import Link from "next/link"; +import { useRouter } from "next/router"; +import { BugAntIcon, MagnifyingGlassIcon, SparklesIcon } from "@heroicons/react/24/outline"; + +interface HeaderMenuLink { + label: string; + href: string; + icon?: React.ReactNode; +} + +export const menuLinks: HeaderMenuLink[] = [ + { + label: "Home", + href: "/", + }, + { + label: "Debug Contracts", + href: "/debug", + icon: , + }, + { + label: "Example UI", + href: "/example-ui", + icon: , + }, + { + label: "Block Explorer", + href: "/blockexplorer", + icon: , + }, +]; + +export const HeaderMenuLinks = () => { + const router = useRouter(); + + return ( + <> + {menuLinks.map(({ label, href, icon }) => { + const isActive = router.pathname === href; + return ( +
  • + + {icon} + {label} + +
  • + ); + })} + + ); +}; diff --git a/packages/nextjs/components/headerMenuLinks.tsx b/packages/nextjs/components/headerMenuLinks.tsx deleted file mode 100644 index 078337839..000000000 --- a/packages/nextjs/components/headerMenuLinks.tsx +++ /dev/null @@ -1,30 +0,0 @@ -import React from "react"; -import { BugAntIcon, MagnifyingGlassIcon, SparklesIcon } from "@heroicons/react/24/outline"; - -interface HeaderMenuLink { - label: string; - href: string; - icon?: React.ReactNode; -} - -export const headerMenuLinks: HeaderMenuLink[] = [ - { - label: "Home", - href: "/", - }, - { - label: "Debug Contracts", - href: "/debug", - icon: , - }, - { - label: "Example UI", - href: "/example-ui", - icon: , - }, - { - label: "Block Explorer", - href: "/blockexplorer", - icon: , - }, -]; diff --git a/packages/nextjs/generated/deployedContracts.ts b/packages/nextjs/generated/deployedContracts.ts index 04fae511f..3d13f1887 100644 --- a/packages/nextjs/generated/deployedContracts.ts +++ b/packages/nextjs/generated/deployedContracts.ts @@ -1,3 +1,154 @@ -const deployedContracts = null; +const contracts = { + 31337: [ + { + chainId: "31337", + name: "localhost", + contracts: { + YourContract: { + address: "0x5FbDB2315678afecb367f032d93F642f64180aa3", + abi: [ + { + inputs: [ + { + internalType: "address", + name: "_owner", + type: "address", + }, + ], + stateMutability: "nonpayable", + type: "constructor", + }, + { + anonymous: false, + inputs: [ + { + indexed: true, + internalType: "address", + name: "greetingSetter", + type: "address", + }, + { + indexed: false, + internalType: "string", + name: "newGreeting", + type: "string", + }, + { + indexed: false, + internalType: "bool", + name: "premium", + type: "bool", + }, + { + indexed: false, + internalType: "uint256", + name: "value", + type: "uint256", + }, + ], + name: "GreetingChange", + type: "event", + }, + { + inputs: [], + name: "greeting", + outputs: [ + { + internalType: "string", + name: "", + type: "string", + }, + ], + stateMutability: "view", + type: "function", + }, + { + inputs: [], + name: "owner", + outputs: [ + { + internalType: "address", + name: "", + type: "address", + }, + ], + stateMutability: "view", + type: "function", + }, + { + inputs: [], + name: "premium", + outputs: [ + { + internalType: "bool", + name: "", + type: "bool", + }, + ], + stateMutability: "view", + type: "function", + }, + { + inputs: [ + { + internalType: "string", + name: "_newGreeting", + type: "string", + }, + ], + name: "setGreeting", + outputs: [], + stateMutability: "payable", + type: "function", + }, + { + inputs: [], + name: "totalCounter", + outputs: [ + { + internalType: "uint256", + name: "", + type: "uint256", + }, + ], + stateMutability: "view", + type: "function", + }, + { + inputs: [ + { + internalType: "address", + name: "", + type: "address", + }, + ], + name: "userGreetingCounter", + outputs: [ + { + internalType: "uint256", + name: "", + type: "uint256", + }, + ], + stateMutability: "view", + type: "function", + }, + { + inputs: [], + name: "withdraw", + outputs: [], + stateMutability: "nonpayable", + type: "function", + }, + { + stateMutability: "payable", + type: "receive", + }, + ], + }, + }, + }, + ], +} as const; -export default deployedContracts; +export default contracts;