2021-07-04 01:42:06 +00:00
|
|
|
import { useState, useEffect } from "react";
|
2021-08-08 22:49:45 +00:00
|
|
|
import { Block } from "@ethersproject/abstract-provider";
|
|
|
|
import { JsonRpcProvider } from "@ethersproject/providers";
|
2021-07-04 01:42:06 +00:00
|
|
|
|
2021-08-08 22:49:45 +00:00
|
|
|
export const useLatestBlock = (provider?: JsonRpcProvider) => {
|
|
|
|
const [latestBlock, setLatestBlock] = useState<Block>();
|
2021-07-04 01:42:06 +00:00
|
|
|
|
|
|
|
useEffect(() => {
|
2021-07-08 19:02:42 +00:00
|
|
|
if (!provider) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2021-07-04 01:42:06 +00:00
|
|
|
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);
|
|
|
|
};
|
2021-07-08 19:02:42 +00:00
|
|
|
}, [provider]);
|
2021-07-04 01:42:06 +00:00
|
|
|
|
|
|
|
return latestBlock;
|
|
|
|
};
|
|
|
|
|
2021-08-08 22:49:45 +00:00
|
|
|
export const useLatestBlockNumber = (provider?: JsonRpcProvider) => {
|
2021-07-04 01:42:06 +00:00
|
|
|
const [latestBlock, setLatestBlock] = useState<number>();
|
|
|
|
|
|
|
|
useEffect(() => {
|
2021-07-08 19:02:42 +00:00
|
|
|
if (!provider) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2021-07-04 01:42:06 +00:00
|
|
|
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);
|
|
|
|
};
|
2021-07-08 19:02:42 +00:00
|
|
|
}, [provider]);
|
2021-07-04 01:42:06 +00:00
|
|
|
|
|
|
|
return latestBlock;
|
|
|
|
};
|