refactor: wallet buttons extracted to Button component

This commit is contained in:
Gustavo Mauricio 2022-09-15 07:55:40 +01:00
parent ace7be48b5
commit 69c4be53a7
2 changed files with 30 additions and 11 deletions

22
components/Button.tsx Normal file
View File

@ -0,0 +1,22 @@
import React from "react";
type Props = {
children: string;
className?: string;
onClick: () => void;
};
const Button = React.forwardRef<any, Props>(
({ children, className = "", onClick }, ref) => (
<button
ref={ref}
onClick={onClick}
className={`rounded-3xl bg-green-500 py-2 px-5 text-white text-sm font-semibold overflow-hidden text-ellipsis ${className}`}
>
{children}
</button>
)
);
Button.displayName = "Button";
export default Button;

View File

@ -3,11 +3,11 @@ import { Popover } from "@headlessui/react";
import { toast } from "react-toastify"; import { toast } from "react-toastify";
import Image from "next/image"; import Image from "next/image";
import { formatWalletAddress } from "utils/formatters"; import Button from "./Button";
import ConnectModal from "./ConnectModal"; import ConnectModal from "./ConnectModal";
import useWalletStore from "stores/useWalletStore"; import useWalletStore from "stores/useWalletStore";
import useInjectiveBalance from "hooks/useInjectiveBalance"; import useInjectiveBalance from "hooks/useInjectiveBalance";
import { formatWalletAddress } from "utils/formatters";
const WalletPopover = ({ children }: { children: React.ReactNode }) => { const WalletPopover = ({ children }: { children: React.ReactNode }) => {
const address = useWalletStore((state) => state.address); const address = useWalletStore((state) => state.address);
@ -17,7 +17,7 @@ const WalletPopover = ({ children }: { children: React.ReactNode }) => {
return ( return (
<Popover className="relative"> <Popover className="relative">
<Popover.Button className="rounded-3xl bg-green-500 py-2 px-2 text-sm font-semibold w-[200px] overflow-hidden text-ellipsis"> <Popover.Button as={Button} className="w-[200px]">
{children} {children}
</Popover.Button> </Popover.Button>
@ -33,12 +33,12 @@ const WalletPopover = ({ children }: { children: React.ReactNode }) => {
</span> </span>
</p> </p>
</div> </div>
<button <Button
className="text-white text-sm bg-[#524bb1] rounded-3xl hover:bg-[#6962cc] cursor-pointer px-5 py-1.5 " className=" bg-[#524bb1] hover:bg-[#6962cc]"
onClick={() => actions.setAddress("")} onClick={() => actions.setAddress("")}
> >
Disconnect Disconnect
</button> </Button>
</div> </div>
<p className="mb-6 text-sm">{address}</p> <p className="mb-6 text-sm">{address}</p>
<button <button
@ -86,12 +86,9 @@ const Wallet = () => {
{hasHydrated && address ? ( {hasHydrated && address ? (
<WalletPopover>{formatWalletAddress(address)}</WalletPopover> <WalletPopover>{formatWalletAddress(address)}</WalletPopover>
) : ( ) : (
<button <Button className="w-[200px]" onClick={() => setShowConnectModal(true)}>
className="rounded-3xl bg-green-500 py-2 px-2 text-sm font-semibold w-[200px]"
onClick={() => setShowConnectModal(true)}
>
Connect Wallet Connect Wallet
</button> </Button>
)} )}
<ConnectModal <ConnectModal
isOpen={showConnectModal} isOpen={showConnectModal}