diff --git a/src/Block.tsx b/src/Block.tsx index 44ae998..ace4653 100644 --- a/src/Block.tsx +++ b/src/Block.tsx @@ -17,6 +17,7 @@ import BlockLink from "./components/BlockLink"; import AddressLink from "./components/AddressLink"; import TransactionValue from "./components/TransactionValue"; import HexValue from "./components/HexValue"; +import { useLatestBlockNumber } from "./useLatestBlock"; type BlockParams = { blockNumberOrHash: string; @@ -96,6 +97,8 @@ const Block: React.FC = () => { } }, [block]); + const latestBlockNumber = useLatestBlockNumber(); + return ( @@ -119,7 +122,10 @@ const Block: React.FC = () => { = latestBlockNumber + } > diff --git a/src/Home.tsx b/src/Home.tsx index 7b7a814..08f1dc8 100644 --- a/src/Home.tsx +++ b/src/Home.tsx @@ -1,9 +1,9 @@ -import React, { useState, useEffect } from "react"; +import React, { useState } from "react"; import { NavLink, useHistory } from "react-router-dom"; import { ethers } from "ethers"; import Logo from "./Logo"; import Timestamp from "./components/Timestamp"; -import { provider } from "./ethersconfig"; +import { useLatestBlock } from "./useLatestBlock"; const Home: React.FC = () => { const [search, setSearch] = useState(); @@ -24,29 +24,7 @@ const Home: React.FC = () => { history.push(`/search?q=${search}`); }; - const [latestBlock, setLatestBlock] = useState(); - useEffect(() => { - const readLatestBlock = async () => { - const blockNum = await provider.getBlockNumber(); - const _raw = await provider.send("erigon_getHeaderByNumber", [blockNum]); - const _block = provider.formatter.block(_raw); - setLatestBlock(_block); - }; - readLatestBlock(); - - const listener = async (blockNumber: number) => { - const _raw = await provider.send("erigon_getHeaderByNumber", [ - blockNumber, - ]); - const _block = provider.formatter.block(_raw); - setLatestBlock(_block); - }; - - provider.on("block", listener); - return () => { - provider.removeListener("block", listener); - }; - }, []); + const latestBlock = useLatestBlock(); document.title = "Home | Otterscan"; diff --git a/src/useLatestBlock.ts b/src/useLatestBlock.ts new file mode 100644 index 0000000..fba4011 --- /dev/null +++ b/src/useLatestBlock.ts @@ -0,0 +1,55 @@ +import { useState, useEffect } from "react"; +import { ethers } from "ethers"; +import { provider } from "./ethersconfig"; + +export const useLatestBlock = () => { + const [latestBlock, setLatestBlock] = useState(); + + useEffect(() => { + const readLatestBlock = async () => { + const blockNum = await provider.getBlockNumber(); + const _raw = await provider.send("erigon_getHeaderByNumber", [blockNum]); + const _block = provider.formatter.block(_raw); + setLatestBlock(_block); + }; + readLatestBlock(); + + const listener = async (blockNumber: number) => { + const _raw = await provider.send("erigon_getHeaderByNumber", [ + blockNumber, + ]); + const _block = provider.formatter.block(_raw); + setLatestBlock(_block); + }; + + provider.on("block", listener); + return () => { + provider.removeListener("block", listener); + }; + }, []); + + return latestBlock; +}; + +export const useLatestBlockNumber = () => { + const [latestBlock, setLatestBlock] = useState(); + + useEffect(() => { + const readLatestBlock = async () => { + const blockNum = await provider.getBlockNumber(); + setLatestBlock(blockNum); + }; + readLatestBlock(); + + const listener = async (blockNumber: number) => { + setLatestBlock(blockNumber); + }; + + provider.on("block", listener); + return () => { + provider.removeListener("block", listener); + }; + }, []); + + return latestBlock; +};