Skip to content

Commit

Permalink
refactor: navbar added keyprops for renderlink and other small changes
Browse files Browse the repository at this point in the history
  • Loading branch information
kevin3656 committed May 19, 2024
1 parent 1e693f4 commit ce35f56
Show file tree
Hide file tree
Showing 5 changed files with 22 additions and 38 deletions.
Binary file added public/images/ijp-logo.webp
Binary file not shown.
1 change: 0 additions & 1 deletion src/components/Buttons.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -274,7 +274,6 @@ export const BigAsyncButton = forwardRef<HTMLButtonElement, AsyncButtonProps>(
);
},
);

BigAsyncButton.displayName = 'BigAsyncButton';

export const BigBlueAsyncButton = forwardRef<
Expand Down
28 changes: 21 additions & 7 deletions src/components/NavBar/index.tsx
Original file line number Diff line number Diff line change
@@ -1,20 +1,26 @@
'use client';

import { useMemo } from 'react';
import Image from 'next/image';
import Link from 'next/link';
import { usePathname } from 'next/navigation';
import Icon from '@/components/Icon';
import COLORS from '@/styles/colors';
import { Flex } from '@/styles/containers';
import { useAuth } from '@/utils/AuthProvider';
import { useProfile } from '@/utils/ProfileProvider';
import IJPlogo from '~/public/images/ijp-logo.webp';
import { ProfileButton, SmallLinkButton } from '../Buttons';
import * as Styles from './style';

export default function NavBar() {
const profile = useProfile();
if (!profile) throw new Error('Profile must be defined.');

const auth = useAuth();
if (!auth) throw new Error('Auth Must be defined.');

const AuthButtonView = useMemo(() => {
if (!profile) throw new Error('Profile must be defined.');
if (profile.profileReady && profile?.profileData)
if (profile.profileReady && auth.userId)
return (
<ProfileButton href="/settings">
{profile.profileData?.first_name || 'Profile'}
Expand Down Expand Up @@ -67,7 +73,7 @@ export default function NavBar() {
];

const renderLink = (link: NavLink) => (
<Styles.LinkContainer>
<Styles.LinkContainer key={link.path}>
<Flex
$direction="column"
$justify="center"
Expand All @@ -91,17 +97,25 @@ export default function NavBar() {
);

const currentPath = usePathname();
if (currentPath.includes('/onboarding')) {
if (currentPath.includes('/onboarding') && !currentPath.includes('/roles')) {
return null;
}

return (
<Styles.NavBarContainer>
<Styles.NavBarSectionDiv>
<Link href="/">
<Icon type="IJPLogo" />
<Image
alt="background"
src={IJPlogo.src}
placeholder="blur"
blurDataURL={IJPlogo.src}
quality={100}
width={47}
height={47}
/>
</Link>
{navlinks.map(NavLink => renderLink(NavLink))}
{navlinks.map(renderLink)}
</Styles.NavBarSectionDiv>
<Styles.NavBarSectionDiv>
<Styles.AuthButtons>{AuthButtonView}</Styles.AuthButtons>
Expand Down
3 changes: 1 addition & 2 deletions src/components/NavBar/style.ts
Original file line number Diff line number Diff line change
Expand Up @@ -44,8 +44,7 @@ export const DisplayText = styled.span<{ $isActive: boolean }>`
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
font-weight: ${({ $isActive }) =>
$isActive ? '600' : '400'};
font-weight: ${({ $isActive }) => ($isActive ? '600' : '400')};
color: white;
`;

Expand Down
28 changes: 0 additions & 28 deletions src/lib/icons.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -216,34 +216,6 @@ export const IconSvgs = {
/>
</svg>
),
IJPLogo: (
<svg
width="48"
height="48"
viewBox="0 0 48 48"
fill="none"
xmlns="http://www.w3.org/2000/svg"
xmlnsXlink="http://www.w3.org/1999/xlink"
>
<rect width="48" height="48" fill="url(#pattern0)" />
<defs>
<pattern
id="pattern0"
patternContentUnits="objectBoundingBox"
width="1"
height="1"
>
<use xlinkHref="#image0_3175_5389" transform="scale(0.00260417)" />
</pattern>
<image
id="image0_3175_5389"
width="384"
height="384"
xlinkHref=""
/>
</defs>
</svg>
),
};

export type IconType = keyof typeof IconSvgs;

0 comments on commit ce35f56

Please sign in to comment.