Merge pull request #169 from blockworks-foundation/align-menus
make menus consistent
This commit is contained in:
commit
11d9a1bff8
|
@ -1,6 +1,6 @@
|
||||||
import { useCallback, useState } from 'react'
|
import { Fragment, useCallback, useState } from 'react'
|
||||||
import useMangoStore from '../stores/useMangoStore'
|
import useMangoStore from '../stores/useMangoStore'
|
||||||
import { Menu } from '@headlessui/react'
|
import { Menu, Transition } from '@headlessui/react'
|
||||||
import {
|
import {
|
||||||
CurrencyDollarIcon,
|
CurrencyDollarIcon,
|
||||||
DuplicateIcon,
|
DuplicateIcon,
|
||||||
|
@ -50,49 +50,63 @@ const ConnectWalletButton = () => {
|
||||||
<>
|
<>
|
||||||
{connected && wallet?.publicKey ? (
|
{connected && wallet?.publicKey ? (
|
||||||
<Menu>
|
<Menu>
|
||||||
<div className="relative" id="profile-menu-tip">
|
{({ open }) => (
|
||||||
<Menu.Button className="bg-th-bkg-4 flex items-center justify-center rounded-full w-10 h-10 text-white focus:outline-none hover:bg-th-bkg-4 hover:text-th-fgd-3">
|
<div className="relative" id="profile-menu-tip">
|
||||||
{pfp?.isAvailable ? (
|
<Menu.Button className="bg-th-bkg-4 flex items-center justify-center rounded-full w-10 h-10 text-white focus:outline-none hover:bg-th-bkg-4 hover:text-th-fgd-3">
|
||||||
<img alt="" src={pfp.url} className="rounded-full" />
|
{pfp?.isAvailable ? (
|
||||||
) : (
|
<img alt="" src={pfp.url} className="rounded-full" />
|
||||||
<ProfileIcon className="h-6 w-6" />
|
) : (
|
||||||
)}
|
<ProfileIcon className="h-6 w-6" />
|
||||||
</Menu.Button>
|
)}
|
||||||
<Menu.Items className="bg-th-bkg-1 mt-2 p-1 absolute right-0 shadow-lg outline-none rounded-md w-48 z-20">
|
</Menu.Button>
|
||||||
<Menu.Item>
|
<Transition
|
||||||
<button
|
appear={true}
|
||||||
className="flex flex-row font-normal items-center rounded-none w-full p-2 hover:bg-th-bkg-2 hover:cursor-pointer focus:outline-none"
|
show={open}
|
||||||
onClick={() => setShowAccountsModal(true)}
|
as={Fragment}
|
||||||
>
|
enter="transition-all ease-in duration-200"
|
||||||
<CurrencyDollarIcon className="h-4 w-4" />
|
enterFrom="opacity-0 transform scale-75"
|
||||||
<div className="pl-2 text-left">{t('accounts')}</div>
|
enterTo="opacity-100 transform scale-100"
|
||||||
</button>
|
leave="transition ease-out duration-200"
|
||||||
</Menu.Item>
|
leaveFrom="opacity-100"
|
||||||
<Menu.Item>
|
leaveTo="opacity-0"
|
||||||
<button
|
>
|
||||||
className="flex flex-row font-normal items-center rounded-none w-full p-2 hover:bg-th-bkg-2 hover:cursor-pointer focus:outline-none"
|
<Menu.Items className="absolute bg-th-bkg-3 mt-1 px-4 py-2.5 right-0 rounded-md space-y-1.5 w-48 z-20">
|
||||||
onClick={() => copyToClipboard(wallet?.publicKey)}
|
<Menu.Item>
|
||||||
>
|
<button
|
||||||
<DuplicateIcon className="h-4 w-4" />
|
className="flex flex-row font-normal items-center py-0.5 rounded-none w-full hover:text-th-primary hover:cursor-pointer focus:outline-none"
|
||||||
<div className="pl-2 text-left">{t('copy-address')}</div>
|
onClick={() => setShowAccountsModal(true)}
|
||||||
</button>
|
>
|
||||||
</Menu.Item>
|
<CurrencyDollarIcon className="h-4 w-4" />
|
||||||
<Menu.Item>
|
<div className="pl-2 text-left">{t('accounts')}</div>
|
||||||
<button
|
</button>
|
||||||
className="flex flex-row font-normal items-center rounded-none w-full p-2 hover:bg-th-bkg-2 hover:cursor-pointer focus:outline-none"
|
</Menu.Item>
|
||||||
onClick={() => wallet.disconnect()}
|
<Menu.Item>
|
||||||
>
|
<button
|
||||||
<LogoutIcon className="h-4 w-4" />
|
className="flex flex-row font-normal items-center py-0.5 rounded-none w-full hover:text-th-primary hover:cursor-pointer focus:outline-none"
|
||||||
<div className="pl-2 text-left">
|
onClick={() => copyToClipboard(wallet?.publicKey)}
|
||||||
<div className="pb-0.5">{t('disconnect')}</div>
|
>
|
||||||
<div className="text-th-fgd-4 text-xs">
|
<DuplicateIcon className="h-4 w-4" />
|
||||||
{abbreviateAddress(wallet?.publicKey)}
|
<div className="pl-2 text-left">{t('copy-address')}</div>
|
||||||
</div>
|
</button>
|
||||||
</div>
|
</Menu.Item>
|
||||||
</button>
|
<Menu.Item>
|
||||||
</Menu.Item>
|
<button
|
||||||
</Menu.Items>
|
className="flex flex-row font-normal items-center py-0.5 rounded-none w-full hover:text-th-primary hover:cursor-pointer focus:outline-none"
|
||||||
</div>
|
onClick={() => wallet.disconnect()}
|
||||||
|
>
|
||||||
|
<LogoutIcon className="h-4 w-4" />
|
||||||
|
<div className="pl-2 text-left">
|
||||||
|
<div className="pb-0.5">{t('disconnect')}</div>
|
||||||
|
<div className="text-th-fgd-4 text-xs">
|
||||||
|
{abbreviateAddress(wallet?.publicKey)}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
|
</Menu.Item>
|
||||||
|
</Menu.Items>
|
||||||
|
</Transition>
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
</Menu>
|
</Menu>
|
||||||
) : (
|
) : (
|
||||||
<div
|
<div
|
||||||
|
|
|
@ -60,7 +60,7 @@ const DropMenu: FunctionComponent<DropMenuProps> = ({
|
||||||
>
|
>
|
||||||
{({ selected }) => (
|
{({ selected }) => (
|
||||||
<div
|
<div
|
||||||
className={`default-transition py-1.5 hover:text-th-primary hover:cursor-pointer tracking-wider whitespace-nowrap ${
|
className={`default-transition text-th-fgd-1 hover:text-th-primary hover:cursor-pointer tracking-wider whitespace-nowrap ${
|
||||||
selected && `text-th-primary`
|
selected && `text-th-primary`
|
||||||
} ${option.icon && `flex items-center`}`}
|
} ${option.icon && `flex items-center`}`}
|
||||||
>
|
>
|
||||||
|
|
|
@ -69,13 +69,13 @@ export default function NavDropMenu({
|
||||||
{linksArray.map(([name, href, isExternal]) =>
|
{linksArray.map(([name, href, isExternal]) =>
|
||||||
!isExternal ? (
|
!isExternal ? (
|
||||||
<Link href={href} key={href}>
|
<Link href={href} key={href}>
|
||||||
<a className="block py-1.5 text-th-fgd-1 whitespace-nowrap hover:text-th-primary">
|
<a className="block py-1 text-th-fgd-1 whitespace-nowrap hover:text-th-primary">
|
||||||
{name}
|
{name}
|
||||||
</a>
|
</a>
|
||||||
</Link>
|
</Link>
|
||||||
) : (
|
) : (
|
||||||
<a
|
<a
|
||||||
className="block py-1.5 text-th-fgd-1 whitespace-nowrap hover:text-th-primary"
|
className="block py-1 text-th-fgd-1 whitespace-nowrap hover:text-th-primary"
|
||||||
href={href}
|
href={href}
|
||||||
key={href}
|
key={href}
|
||||||
target="_blank"
|
target="_blank"
|
||||||
|
|
|
@ -37,14 +37,14 @@ export default function WalletSelect() {
|
||||||
leaveFrom="opacity-100"
|
leaveFrom="opacity-100"
|
||||||
leaveTo="opacity-0"
|
leaveTo="opacity-0"
|
||||||
>
|
>
|
||||||
<Menu.Items className="absolute bg-th-bkg-1 divide-y divide-th-bkg-3 rounded-md right-0 mt-1 shadow-lg outline-none w-44 z-20">
|
<Menu.Items className="absolute bg-th-bkg-3 px-4 py-2.5 rounded-b-md right-0 outline-none w-44 z-20">
|
||||||
{WALLET_PROVIDERS.map(({ name, url, icon }) => (
|
{WALLET_PROVIDERS.map(({ name, url, icon }) => (
|
||||||
<Menu.Item key={name}>
|
<Menu.Item key={name}>
|
||||||
<button
|
<button
|
||||||
className="flex flex-row items-center justify-between rounded-none text-xs w-full p-2 hover:bg-th-bkg-2 hover:cursor-pointer font-normal focus:outline-none"
|
className="flex flex-row items-center justify-between py-1 rounded-none w-full hover:text-th-primary hover:cursor-pointer font-normal focus:outline-none"
|
||||||
onClick={() => handleSelectProvider(url)}
|
onClick={() => handleSelectProvider(url)}
|
||||||
>
|
>
|
||||||
<div className="flex">
|
<div className="flex items-center">
|
||||||
<img src={icon} className="w-4 h-4 mr-2" />
|
<img src={icon} className="w-4 h-4 mr-2" />
|
||||||
{name}
|
{name}
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -98,7 +98,7 @@ a {
|
||||||
}
|
}
|
||||||
|
|
||||||
li {
|
li {
|
||||||
@apply mb-2 text-sm text-th-fgd-3 last:mb-0;
|
@apply mb-2.5 text-sm text-th-fgd-3 last:mb-0;
|
||||||
}
|
}
|
||||||
|
|
||||||
tbody {
|
tbody {
|
||||||
|
|
Loading…
Reference in New Issue