2022-12-19 15:59:14 -08:00
|
|
|
import type {
|
|
|
|
|
MenuProps as MantineMenuProps,
|
|
|
|
|
MenuItemProps as MantineMenuItemProps,
|
|
|
|
|
MenuLabelProps as MantineMenuLabelProps,
|
|
|
|
|
MenuDividerProps as MantineMenuDividerProps,
|
|
|
|
|
MenuDropdownProps as MantineMenuDropdownProps,
|
|
|
|
|
} from '@mantine/core';
|
|
|
|
|
import { Menu as MantineMenu, createPolymorphicComponent } from '@mantine/core';
|
2022-12-22 01:59:02 -08:00
|
|
|
import { RiArrowLeftSFill } from 'react-icons/ri';
|
2022-12-19 15:59:14 -08:00
|
|
|
import styled from 'styled-components';
|
|
|
|
|
|
|
|
|
|
type MenuProps = MantineMenuProps;
|
|
|
|
|
type MenuLabelProps = MantineMenuLabelProps;
|
|
|
|
|
interface MenuItemProps extends MantineMenuItemProps {
|
|
|
|
|
$isActive?: boolean;
|
|
|
|
|
children: React.ReactNode;
|
|
|
|
|
}
|
|
|
|
|
type MenuDividerProps = MantineMenuDividerProps;
|
|
|
|
|
type MenuDropdownProps = MantineMenuDropdownProps;
|
|
|
|
|
|
|
|
|
|
const StyledMenu = styled(MantineMenu)<MenuProps>``;
|
|
|
|
|
|
|
|
|
|
const StyledMenuLabel = styled(MantineMenu.Label)<MenuLabelProps>`
|
|
|
|
|
font-family: var(--content-font-family);
|
|
|
|
|
`;
|
|
|
|
|
|
|
|
|
|
const StyledMenuItem = styled(MantineMenu.Item)<MenuItemProps>`
|
|
|
|
|
padding: 0.8rem;
|
|
|
|
|
font-size: 0.9em;
|
|
|
|
|
font-family: var(--content-font-family);
|
|
|
|
|
|
|
|
|
|
&:disabled {
|
|
|
|
|
opacity: 0.6;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
&:hover {
|
|
|
|
|
background-color: var(--dropdown-menu-bg-hover);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
& .mantine-Menu-itemIcon {
|
|
|
|
|
margin-right: 0.5rem;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
& .mantine-Menu-itemLabel {
|
2022-12-22 01:59:02 -08:00
|
|
|
color: var(--dropdown-menu-fg);
|
2022-12-19 15:59:14 -08:00
|
|
|
font-weight: 500;
|
|
|
|
|
font-size: 1em;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
& .mantine-Menu-itemRightSection {
|
|
|
|
|
display: flex;
|
|
|
|
|
margin-left: 2rem !important;
|
|
|
|
|
color: ${({ $isActive }) => ($isActive ? 'var(--primary-color)' : 'var(--dropdown-menu-fg)')};
|
|
|
|
|
}
|
|
|
|
|
`;
|
|
|
|
|
|
|
|
|
|
const StyledMenuDropdown = styled(MantineMenu.Dropdown)`
|
|
|
|
|
background: var(--dropdown-menu-bg);
|
|
|
|
|
border: var(--dropdown-menu-border);
|
|
|
|
|
border-radius: var(--dropdown-menu-border-radius);
|
|
|
|
|
filter: drop-shadow(0 0 5px rgb(0, 0, 0, 50%));
|
|
|
|
|
`;
|
|
|
|
|
|
|
|
|
|
const StyledMenuDivider = styled(MantineMenu.Divider)`
|
|
|
|
|
margin: 0.3rem 0;
|
|
|
|
|
`;
|
|
|
|
|
|
|
|
|
|
export const DropdownMenu = ({ children, ...props }: MenuProps) => {
|
|
|
|
|
return (
|
|
|
|
|
<StyledMenu
|
2022-12-22 01:59:02 -08:00
|
|
|
withArrow
|
2022-12-19 15:59:14 -08:00
|
|
|
withinPortal
|
|
|
|
|
radius="sm"
|
|
|
|
|
styles={{
|
|
|
|
|
dropdown: {
|
|
|
|
|
filter: 'drop-shadow(0 0 5px rgb(0, 0, 0, 50%))',
|
|
|
|
|
},
|
|
|
|
|
}}
|
|
|
|
|
transition="scale"
|
|
|
|
|
{...props}
|
|
|
|
|
>
|
|
|
|
|
{children}
|
|
|
|
|
</StyledMenu>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const MenuLabel = ({ children, ...props }: MenuLabelProps) => {
|
|
|
|
|
return <StyledMenuLabel {...props}>{children}</StyledMenuLabel>;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const pMenuItem = ({ $isActive, children, ...props }: MenuItemProps) => {
|
|
|
|
|
return (
|
|
|
|
|
<StyledMenuItem
|
|
|
|
|
$isActive={$isActive}
|
2022-12-22 01:59:02 -08:00
|
|
|
rightSection={$isActive && <RiArrowLeftSFill size={20} />}
|
2022-12-19 15:59:14 -08:00
|
|
|
{...props}
|
|
|
|
|
>
|
|
|
|
|
{children}
|
|
|
|
|
</StyledMenuItem>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const MenuDropdown = ({ children, ...props }: MenuDropdownProps) => {
|
|
|
|
|
return <StyledMenuDropdown {...props}>{children}</StyledMenuDropdown>;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const MenuItem = createPolymorphicComponent<'button', MenuItemProps>(pMenuItem);
|
|
|
|
|
|
|
|
|
|
const MenuDivider = ({ ...props }: MenuDividerProps) => {
|
|
|
|
|
return <StyledMenuDivider {...props} />;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
DropdownMenu.Label = MenuLabel;
|
|
|
|
|
DropdownMenu.Item = MenuItem;
|
|
|
|
|
DropdownMenu.Target = MantineMenu.Target;
|
|
|
|
|
DropdownMenu.Dropdown = MenuDropdown;
|
|
|
|
|
DropdownMenu.Divider = MenuDivider;
|