From f991fdcd2e924ec4ac60950fd5ac13074394766e Mon Sep 17 00:00:00 2001 From: Frederik Bolding Date: Fri, 26 Jul 2024 11:42:40 +0200 Subject: [PATCH] Add pages for chains (#136) * Experiment with chain pages * More progress on chain pages * Move providers to root * Add flags and improve styling * Add gatsby-ssr * More responsiveness and fixes --- gatsby-browser.jsx | 9 ++ gatsby-node.js | 2 + gatsby-ssr.jsx | 9 ++ src/components/Chain.tsx | 99 +++++++++-------- src/components/ChainIcon.tsx | 4 +- src/components/ExternalLink.tsx | 9 ++ src/components/Header.tsx | 7 +- src/components/Layout.tsx | 9 +- src/components/RedFlagBadge.tsx | 20 ++++ src/components/RpcTable.tsx | 45 ++++++++ src/components/StatValue.tsx | 8 ++ src/components/StatusBadge.tsx | 13 +++ src/pages/chain/{Chain.chainId}.tsx | 159 ++++++++++++++++++++++++++++ src/pages/index.tsx | 13 +-- src/types/chain.ts | 3 + 15 files changed, 350 insertions(+), 59 deletions(-) create mode 100644 gatsby-browser.jsx create mode 100644 gatsby-ssr.jsx create mode 100644 src/components/ExternalLink.tsx create mode 100644 src/components/RedFlagBadge.tsx create mode 100644 src/components/RpcTable.tsx create mode 100644 src/components/StatValue.tsx create mode 100644 src/components/StatusBadge.tsx create mode 100644 src/pages/chain/{Chain.chainId}.tsx diff --git a/gatsby-browser.jsx b/gatsby-browser.jsx new file mode 100644 index 000000000..5789734d5 --- /dev/null +++ b/gatsby-browser.jsx @@ -0,0 +1,9 @@ +import React from "react"; +import { Web3Provider } from "./src/context/Web3Context"; +import { SearchProvider } from "./src/context/SearchContext"; + +export const wrapRootElement = ({ element }) => ( + + {element} + +); diff --git a/gatsby-node.js b/gatsby-node.js index 4cb348aed..fb0c0c126 100644 --- a/gatsby-node.js +++ b/gatsby-node.js @@ -65,6 +65,8 @@ exports.sourceNodes = async ({ }, Promise.resolve({})); chains + // Filter out non HTTP(S) RPC URLs + .map((chain) => ({ ...chain, rpc: chain.rpc.filter(rpc => rpc.startsWith('http://') || rpc.startsWith('https://'))})) .filter((chain) => chain.rpc.length > 0) .forEach((chain) => { const icon = chain.icon; diff --git a/gatsby-ssr.jsx b/gatsby-ssr.jsx new file mode 100644 index 000000000..5789734d5 --- /dev/null +++ b/gatsby-ssr.jsx @@ -0,0 +1,9 @@ +import React from "react"; +import { Web3Provider } from "./src/context/Web3Context"; +import { SearchProvider } from "./src/context/SearchContext"; + +export const wrapRootElement = ({ element }) => ( + + {element} + +); diff --git a/src/components/Chain.tsx b/src/components/Chain.tsx index f4ee98a71..1ed2fb8c7 100644 --- a/src/components/Chain.tsx +++ b/src/components/Chain.tsx @@ -12,6 +12,7 @@ import React, { useContext } from "react"; import { Web3Context } from "../context/Web3Context"; import { ChainData } from "../types/chain"; import { ChainIcon } from "./ChainIcon"; +import { Link } from "gatsby"; export const Chain = ({ name, @@ -22,55 +23,65 @@ export const Chain = ({ }: ChainData) => { const { isConnected, handleConnect, handleAddChain } = useContext(Web3Context); - const handleAddChainClick = () => { + + const handleConnectClick = (event: React.MouseEvent) => { + event.preventDefault(); + handleConnect(); + }; + + const handleAddChainClick = (event: React.MouseEvent) => { + event.preventDefault(); handleAddChain({ name, chainId, nativeCurrency, ...rest }); }; + return ( - - - - - - {name} - + + + + + + + {name} + + + + + Chain ID + {chainId} + + + Currency + {nativeCurrency.symbol} + + - - - Chain ID - {chainId} - - - Currency - {nativeCurrency.symbol} - - + {icon && ( + + + + )} - {icon && ( - - - - )} +
+ {!isConnected ? ( + + ) : ( + + )} +
-
- {!isConnected ? ( - - ) : ( - - )} -
-
+ ); }; diff --git a/src/components/ChainIcon.tsx b/src/components/ChainIcon.tsx index dc85ff24c..3ad80074b 100644 --- a/src/components/ChainIcon.tsx +++ b/src/components/ChainIcon.tsx @@ -3,7 +3,7 @@ import { GatsbyImage } from "gatsby-plugin-image"; import { ChainData } from "../types/chain"; import { Image } from "@chakra-ui/react"; -export const ChainIcon = ({ icon, name }: Pick) => +export const ChainIcon = ({ icon, name, width = "40px" }: Pick & { width?: string; }) => icon.childImageSharp ? ( ) => alt={name} /> ) : ( - + ); diff --git a/src/components/ExternalLink.tsx b/src/components/ExternalLink.tsx new file mode 100644 index 000000000..667b220e1 --- /dev/null +++ b/src/components/ExternalLink.tsx @@ -0,0 +1,9 @@ +import React from "react"; +import { ExternalLinkIcon } from "@chakra-ui/icons"; +import { Link } from "@chakra-ui/react"; + +export const ExternalLink = ({ href, children }) => ( + + {children} + +); diff --git a/src/components/Header.tsx b/src/components/Header.tsx index 7573c1610..84a6858d1 100644 --- a/src/components/Header.tsx +++ b/src/components/Header.tsx @@ -14,6 +14,7 @@ import { Search } from "./Search"; import { FaGithub } from "react-icons/fa"; import { AddIcon } from "@chakra-ui/icons"; import { Filters } from "./Filters"; +import { Link as GatsbyLink } from "gatsby"; export const Header = ({ showSearch = true, showFilters = true }) => { const { handleConnect, isConnected, address } = useContext(Web3Context); @@ -33,7 +34,9 @@ export const Header = ({ showSearch = true, showFilters = true }) => { width="100%" zIndex="sticky" > - Chainlist + + Chainlist + {showSearch && } {showFilters && } @@ -62,7 +65,7 @@ export const Header = ({ showSearch = true, showFilters = true }) => { size="lg" onClick={handleConnect} > - Connect Wallet + Connect ) : ( + ) : ( + + )} + + + + + Chain ID + + {chainId} + + + + Currency + + {nativeCurrency.symbol} + + + + Status + + + + + + {infoURL && ( + + Info + + {infoURL} + + + )} + {explorers && ( + + Explorers + + {explorers.map((explorer) => ( + + {explorer.url} + + ))} + + + )} + + + +
+ + + ); +}; + +export const query = graphql` + query ($id: String) { + chain(id: { eq: $id }) { + id + name + chain + chainId + rpc + icon { + publicURL + childImageSharp { + gatsbyImageData(width: 60, placeholder: NONE) + } + } + nativeCurrency { + decimals + name + symbol + } + explorers { + url + name + standard + } + status + faucets + redFlags + infoURL + } + } +`; + +export default ChainPage; diff --git a/src/pages/index.tsx b/src/pages/index.tsx index 051a31179..8ce559e50 100644 --- a/src/pages/index.tsx +++ b/src/pages/index.tsx @@ -1,21 +1,14 @@ -import { graphql, useStaticQuery } from "gatsby"; import React from "react"; import { ChainList } from "../components/ChainList"; import { Seo } from "../components/SEO"; -import { Web3Provider } from "../context/Web3Context"; -import { SearchProvider } from "../context/SearchContext"; import { Layout } from "../components/Layout"; const IndexPage = () => ( <> - - - - - - - + + + ); diff --git a/src/types/chain.ts b/src/types/chain.ts index 5ca376aac..42100bcfc 100644 --- a/src/types/chain.ts +++ b/src/types/chain.ts @@ -11,6 +11,9 @@ export interface ChainData { chainId: number; nativeCurrency: ChainCurrency; explorers?: BlockExplorer[]; + status?: string; + redFlags?: string[]; + infoURL?: string; } export interface ChainCurrency {