Skip to content

Commit

Permalink
feat: update navbar to support custom size and colors
Browse files Browse the repository at this point in the history
  • Loading branch information
0xKurt committed Dec 6, 2024
1 parent 089b35b commit a30444e
Show file tree
Hide file tree
Showing 3 changed files with 110 additions and 62 deletions.
10 changes: 5 additions & 5 deletions src/assets/icons/custom/checker.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
89 changes: 63 additions & 26 deletions src/primitives/Navbar/Navbar.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,26 +12,22 @@ const meta = {
title: "Primitives/Navbar",
component: Navbar,
args: {
text: "My Navbar",
text: {
text: "My Navbar",
},
},
argTypes: {
primaryLogo: {
control: "text",
control: "object",
},
secondaryLogo: {
control: "text",
},
primaryLogoLink: {
control: "text",
control: "object",
},
secondaryLogoLink: {
control: "text",
},
textLink: {
control: "text",
showDivider: {
control: "boolean",
},
text: {
control: "text",
control: "object",
},
children: {
control: "text",
Expand All @@ -45,36 +41,77 @@ type Story = StoryObj<typeof Navbar>;

export const Default: Story = {
args: {
primaryLogoLink: "#",
secondaryLogo: CheckerIcon,
secondaryLogoLink: "#",
textLink: "#",
primaryLogo: {
link: "#",
},
text: {
text: "My Navbar",
link: "#",
},
},
};

export const WithSecondaryLogo: Story = {
args: {
primaryLogoLink: "#",
secondaryLogo: DefaultLogo,
secondaryLogoLink: "#",
textLink: "#",
primaryLogo: {
link: "#",
},
secondaryLogo: {
img: DefaultLogo,
link: "#",
},
text: {
text: "My Navbar",
link: "#",
},
},
};

export const WithCustomTextAndWithoutDivider: Story = {
args: {
primaryLogoLink: "#",
text: "Custom Navbar",
textLink: "#",
primaryLogo: {
link: "#",
},
text: {
text: "Custom Navbar",
link: "#",
},
showDivider: false,
},
};

export const WithChildren: Story = {
args: {
secondaryLogo: DefaultLogo,
secondaryLogoLink: "#",
textLink: "#",
secondaryLogo: {
img: DefaultLogo,
link: "#",
},
text: {
text: "My Navbar",
link: "#",
},
children: <Button value="Connect Wallet" />,
},
};

export const WithCustomSizeAndColor: Story = {
args: {
primaryLogo: {
img: DefaultLogo,
link: "#",
size: "h-16 w-16",
color: "blue-500",
},
secondaryLogo: {
img: CheckerIcon,
link: "#",
size: "w-8",
color: "moss-500",
},
text: {
text: "Custom Size and Color Navbar",
link: "#",
className: "text-xl text-purple-700",
},
},
};
73 changes: 42 additions & 31 deletions src/primitives/Navbar/Navbar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,21 +11,30 @@ const navbarVariants = tv({
base: "top-0 flex h-[64px] w-full shrink-0 flex-col items-center justify-center gap-2 p-[10px_80px]",
container: "flex w-full items-center justify-between",
leftSection: "flex items-center gap-4",
logo: "h-10 max-w-12",
divider: "h-4 border-r border-grey-700",
text: "text-lg font-semibold",
text: "font-mono text-lg",
rightSection: "flex items-center",
},
});

interface LogoProps {
link?: string;
img?: string | React.FunctionComponent<React.SVGAttributes<SVGElement>>;
size?: string;
color?: string;
}

interface TextProps {
text: string;
link?: string;
className?: string;
}

export interface NavbarProps {
primaryLogo?: string | React.FunctionComponent<React.SVGAttributes<SVGElement>>;
secondaryLogo?: string | React.FunctionComponent<React.SVGAttributes<SVGElement>>;
primaryLogo?: LogoProps;
secondaryLogo?: LogoProps;
showDivider?: boolean;
text: string;
primaryLogoLink?: string;
secondaryLogoLink?: string;
textLink?: string;
text: TextProps;
children?: React.ReactNode;
}

Expand All @@ -34,46 +43,48 @@ export const Navbar = ({
secondaryLogo,
showDivider = true,
text,
primaryLogoLink,
secondaryLogoLink,
textLink,
children,
}: NavbarProps) => {
const {
base,
container,
leftSection,
logo,
divider,
text: textStyle,
rightSection,
} = navbarVariants();
const { base, container, leftSection, divider, text: textStyle, rightSection } = navbarVariants();

const renderLogo = ({ link, img, size = "h-10 max-w-12", color = "black" }: LogoProps) => {
const logoClasses = `${size} text-${color}`;

const renderLogo = (
img: string | React.FunctionComponent<React.SVGAttributes<SVGElement>> | undefined,
) => {
if (!img) {
return <img src={defaultLogo} alt="Default Logo" className={logo()} />;
return (
<img src={defaultLogo} alt="Default Logo" className={logoClasses} />
);
}

if (typeof img === "string") {
return <img src={img} alt="Logo" className={logo()} />;
return <img src={img} alt="Logo" className={logoClasses} />;
}

const LogoComponent = img;
return <LogoComponent className={logo()} />;
return (
<a href={link || "#"}>
<LogoComponent className={logoClasses} />
</a>
);
};

const renderText = ({ text, link, className = "" }: TextProps) => {
const textClasses = `${textStyle()} ${className}`;
return (
<a href={link || "#"} className={textClasses}>
{text}
</a>
);
};

return (
<nav className={base()}>
<div className={container()}>
<div className={leftSection()}>
<a href={primaryLogoLink || "#"}>{renderLogo(primaryLogo)}</a>
{renderLogo(primaryLogo || {})}
{showDivider && <div className={divider()}></div>}
{secondaryLogo && <a href={secondaryLogoLink || "#"}>{renderLogo(secondaryLogo)}</a>}
<a href={textLink || "#"} className={textStyle()}>
{text}
</a>
{secondaryLogo && renderLogo(secondaryLogo)}
{renderText(text)}
</div>
<div className={rightSection()}>{children}</div>
</div>
Expand Down

0 comments on commit a30444e

Please sign in to comment.