Skip to content

Commit

Permalink
Merge pull request #294 from EveripediaNetwork/sidebar-improvement
Browse files Browse the repository at this point in the history
Sidebar improvement
  • Loading branch information
Damola18 authored Jan 16, 2025
2 parents c6705f3 + 68cb639 commit a1f3134
Show file tree
Hide file tree
Showing 2 changed files with 49 additions and 37 deletions.
2 changes: 1 addition & 1 deletion src/components/client/TreasuryPage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ const TreasuryPage: NextPage = () => {
href="https://etherscan.io/address/0x56398b89d53e8731bca8c1b06886cfb14bd6b654"
isExternal
>
IQ.eth
IQ.eth{' '}
</Link>
</Box>
<Box as="span">{t('treasury')}</Box>
Expand Down
84 changes: 48 additions & 36 deletions src/components/dashboard/sidebar-item.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import { Flex, FlexProps, Icon, LinkBox, Image } from '@chakra-ui/react'
import { dataAttr } from '@chakra-ui/utils'
import { usePathname } from 'next/navigation'
import React from 'react'
import Link from 'next/link'
import LinkOverlay from '../elements/LinkElements/LinkOverlay'
import { useTranslations } from 'next-intl'

Expand All @@ -20,46 +21,57 @@ export const SidebarItem = (props: SidebarItemProps) => {

const pathname = usePathname()
const isActiveRoute = pathname?.endsWith(item.route)
const isExternalLink = item.route.startsWith('http')

const renderLinkContent = () => (
<Flex
h="40px"
align="center"
pl={{ base: 5, lg: '15' }}
cursor="pointer"
data-active={dataAttr(isActiveRoute)}
color="grayText"
fontWeight="medium"
_hover={{
bg: 'divider',
color: 'dimmedText',
}}
_active={{
bg: 'hoverBg',
color: 'brandText',
}}
transition="all .2s ease"
position="relative"
gap="2"
>
{typeof item.icon === 'string' ? (
<Image src={item.icon} boxSize="6" alt="icon" />
) : (
<Icon as={item.icon} boxSize="6" />
)}
{t(item.label)}
{isActiveRoute && (
<NavIndicator position="absolute" right="0" bg="transparent" />
)}
</Flex>
)

return (
<LinkBox {...rest}>
<LinkOverlay href={item.route} target={item.target} onClick={onClose}>
<Flex
h="40px"
align="center"
pl={{ base: 5, lg: '15' }}
cursor="pointer"
data-active={dataAttr(isActiveRoute)}
color="grayText"
fontWeight="medium"
_hover={{
bg: 'divider',
color: 'dimmedText',
}}
_active={{
bg: 'hoverBg',
color: 'brandText',
}}
transition="all .2s ease"
role="group"
display="flex"
gap="2"
{isExternalLink ? (
<Link
href={item.route}
target="_blank"
rel="noopener noreferrer"
onClick={onClose}
>
{typeof item.icon === 'string' ? (
<Image src={item.icon} boxSize="6" alt="icon" />
) : (
<Icon as={item.icon} boxSize="6" />
)}
{t(item.label)}
<NavIndicator
display="none"
_groupActive={{
display: 'inherit',
}}
ml="auto"
/>
</Flex>
</LinkOverlay>
{renderLinkContent()}
</Link>
) : (
<LinkOverlay href={item.route} target={item.target} onClick={onClose}>
{renderLinkContent()}
</LinkOverlay>
)}
</LinkBox>
)
}

0 comments on commit a1f3134

Please sign in to comment.