36 lines
908 B
TypeScript
36 lines
908 B
TypeScript
import { NavLink } from "react-router-dom";
|
|
import { BlockTag } from "@ethersproject/abstract-provider";
|
|
import { blockURL } from "../url";
|
|
|
|
type NavButtonProps = {
|
|
blockNum: number;
|
|
disabled?: boolean;
|
|
urlBuilder?: (blockNumber: BlockTag) => string;
|
|
};
|
|
|
|
const NavButton: React.FC<NavButtonProps> = ({
|
|
blockNum,
|
|
disabled,
|
|
urlBuilder,
|
|
children,
|
|
}) => {
|
|
if (disabled) {
|
|
return (
|
|
<span className="bg-link-blue bg-opacity-10 text-gray-400 rounded px-2 py-1 text-xs">
|
|
{children}
|
|
</span>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<NavLink
|
|
className="transition-colors bg-link-blue bg-opacity-10 text-link-blue hover:bg-opacity-100 hover:text-white disabled:bg-link-blue disabled:text-gray-400 disabled:cursor-default rounded px-2 py-1 text-xs"
|
|
to={urlBuilder ? urlBuilder(blockNum) : blockURL(blockNum)}
|
|
>
|
|
{children}
|
|
</NavLink>
|
|
);
|
|
};
|
|
|
|
export default NavButton;
|