mirror of
https://github.com/vercel/commerce.git
synced 2025-07-06 05:01:20 +00:00
42 lines
1.2 KiB
TypeScript
42 lines
1.2 KiB
TypeScript
import classNames from 'classnames';
|
|
import Link from 'next/link';
|
|
import React from 'react';
|
|
import s from './MenuDropdown.module.scss';
|
|
|
|
interface Props {
|
|
children?: React.ReactNode,
|
|
options: { link: string, name: string }[],
|
|
isHasArrow?: boolean,
|
|
align?: 'left'
|
|
}
|
|
|
|
const MenuDropdown = ({ options, children, isHasArrow = true, align }: Props) => {
|
|
return (
|
|
<div className={classNames({
|
|
[s.menuDropdown]: true,
|
|
[s.arrow]: isHasArrow,
|
|
})}>
|
|
<span className={s.label}>
|
|
{children}
|
|
</span>
|
|
<section className={classNames({
|
|
[s.menu]: true,
|
|
[s.left]: align === 'left',
|
|
})} >
|
|
<ul className={s.menuIner}>
|
|
{
|
|
options.map(item => <li key={item.name}>
|
|
<Link href={item.link}>
|
|
<a >
|
|
{item.name}
|
|
</a>
|
|
</Link>
|
|
</li>)
|
|
}
|
|
</ul>
|
|
</section>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default MenuDropdown; |