import Link from 'next/link' import { EllipsisHorizontalIcon, BuildingLibraryIcon, ArrowTopRightOnSquareIcon, ChevronDownIcon, CurrencyDollarIcon, ChartBarIcon, ArrowsRightLeftIcon, ArrowTrendingUpIcon, MagnifyingGlassIcon, BanknotesIcon, NewspaperIcon, PlusCircleIcon, ArchiveBoxArrowDownIcon, ExclamationTriangleIcon, DocumentTextIcon, } from '@heroicons/react/20/solid' import { useRouter } from 'next/router' import { useTranslation } from 'next-i18next' import { Fragment, ReactNode, useEffect, useMemo } from 'react' import { Disclosure, Popover, Transition } from '@headlessui/react' import MangoAccountSummary from './account/MangoAccountSummary' import Tooltip from './shared/Tooltip' import { HealthType } from '@blockworks-foundation/mango-v4' import { useWallet } from '@solana/wallet-adapter-react' import mangoStore from '@store/mangoStore' import HealthHeart from './account/HealthHeart' import useMangoAccount from 'hooks/useMangoAccount' import { useTheme } from 'next-themes' import LeaderboardIcon from './icons/LeaderboardIcon' import { sideBarAnimationDuration } from './Layout' import { CUSTOM_SKINS, breakpoints } from 'utils/theme' import { NFT } from 'types' import { useViewport } from 'hooks/useViewport' import useLocalStorageState from 'hooks/useLocalStorageState' import { CUSTOM_THEME_SUFFIX, SIDEBAR_COLLAPSE_KEY } from 'utils/constants' import { createTransferInstruction } from '@solana/spl-token' import { PublicKey, TransactionInstruction } from '@solana/web3.js' const set = mangoStore.getState().set const SideNav = ({ collapsed }: { collapsed: boolean }) => { const { t } = useTranslation(['common', 'search']) const { connected, publicKey } = useWallet() const { theme, setTheme } = useTheme() const group = mangoStore.getState().group const themeData = mangoStore((s) => s.themeData) const nfts = mangoStore((s) => s.wallet.nfts.data) const loadingNfts = mangoStore((s) => s.wallet.nfts.initialLoad) const { mangoAccount } = useMangoAccount() const setPrependedGlobalAdditionalInstructions = mangoStore( (s) => s.actions.setPrependedGlobalAdditionalInstructions, ) const [customTheme] = useLocalStorageState( `${publicKey}${CUSTOM_THEME_SUFFIX}`, '', ) const router = useRouter() const { pathname } = router const { width } = useViewport() const [, setIsCollapsed] = useLocalStorageState(SIDEBAR_COLLAPSE_KEY, false) useEffect(() => { if (width !== 0 && width < breakpoints['2xl']) { setIsCollapsed(true) } }, [width, setIsCollapsed]) const playAnimation = () => { const set = mangoStore.getState().set set((s) => { s.successAnimation.theme = true }) } // fetch nfts when pk changes useEffect(() => { if (publicKey) { set((state) => { state.wallet.nfts.initialLoad = true }) const actions = mangoStore.getState().actions const connection = mangoStore.getState().connection actions.fetchNfts(connection, publicKey) } }, [publicKey]) // find all mango skin nfts const mangoNfts = useMemo(() => { if (!nfts.length) return [] const mangoNfts: NFT[] = [] for (const nft of nfts) { const collectionAddress = nft?.collectionAddress for (const themeKey in CUSTOM_SKINS) { if (CUSTOM_SKINS[themeKey] === collectionAddress) { mangoNfts.push(nft) } } } return mangoNfts }, [nfts]) //mark transactions with used nfts useEffect(() => { let newInstruction: TransactionInstruction[] = [] if (mangoNfts.length && theme) { const collectionAddress = CUSTOM_SKINS[theme.toLowerCase()] const usedNft = mangoNfts.find( (nft) => nft.collectionAddress === collectionAddress, ) if (usedNft && publicKey && collectionAddress) { newInstruction = [ createTransferInstruction( new PublicKey(usedNft.tokenAccount), new PublicKey(usedNft.tokenAccount), publicKey, 1, ), ] } } setPrependedGlobalAdditionalInstructions(newInstruction) }, [mangoNfts, theme, themeData]) // find sidebar image url from skin nft for theme const sidebarImageUrl = useMemo(() => { if (!theme) return themeData.sideImagePath const collectionAddress = CUSTOM_SKINS[theme.toLowerCase()] if (collectionAddress && mangoNfts.length) { const attributes = mangoNfts.find( (nft) => nft.collectionAddress === collectionAddress, )?.json?.attributes const sidebarImageUrl = attributes ? attributes[0].value || themeData.sideImagePath : '' return sidebarImageUrl } return themeData.sideImagePath }, [mangoNfts, theme, themeData]) // change theme if switching to wallet without nft useEffect(() => { if (loadingNfts || !theme) return const hasSkin = mangoNfts.find( (nft) => nft.collectionAddress === CUSTOM_SKINS[customTheme.toLowerCase()], ) if (hasSkin && customTheme && theme !== customTheme) { setTheme(customTheme) } else if (!hasSkin) { setTheme( CUSTOM_SKINS[theme.toLowerCase()] ? t('settings:mango-classic') : theme, ) } }, [loadingNfts, mangoNfts, publicKey, theme]) return (
{t('account')}
{mangoAccount ? mangoAccount.name : connected ? 'No Account' : 'Connect'}