I changed the visibility of the search dialog to make it full screen on mobile, this should already be ok but I couldn't try it on mobile, so I just used devtools, if I need to do something else on this PR just tell me :) This PR aims to fix: #5746 --------- Co-authored-by: Félix Malfait <felix.malfait@gmail.com>
115 lines
3.0 KiB
TypeScript
115 lines
3.0 KiB
TypeScript
import { useTheme } from '@emotion/react';
|
|
import styled from '@emotion/styled';
|
|
import { IconComponent } from 'twenty-ui';
|
|
|
|
import { useIsMobile } from '@/ui/utilities/responsive/hooks/useIsMobile';
|
|
|
|
import {
|
|
StyledMenuItemLabel,
|
|
StyledMenuItemLeftContent,
|
|
} from '../internals/components/StyledMenuItemBase';
|
|
|
|
import { MenuItemCommandHotKeys } from './MenuItemCommandHotKeys';
|
|
|
|
const StyledMenuItemLabelText = styled(StyledMenuItemLabel)`
|
|
color: ${({ theme }) => theme.font.color.primary};
|
|
`;
|
|
|
|
const StyledBigIconContainer = styled.div`
|
|
align-items: center;
|
|
background: ${({ theme }) => theme.background.transparent.light};
|
|
border-radius: ${({ theme }) => theme.border.radius.sm};
|
|
|
|
display: flex;
|
|
|
|
flex-direction: row;
|
|
|
|
padding: ${({ theme }) => theme.spacing(1)};
|
|
`;
|
|
|
|
const StyledMenuItemCommandContainer = styled.div<{ isSelected?: boolean }>`
|
|
--horizontal-padding: ${({ theme }) => theme.spacing(1)};
|
|
--vertical-padding: ${({ theme }) => theme.spacing(2)};
|
|
align-items: center;
|
|
background: ${({ isSelected, theme }) =>
|
|
isSelected
|
|
? theme.background.transparent.light
|
|
: theme.background.secondary};
|
|
border-radius: ${({ theme }) => theme.border.radius.sm};
|
|
color: ${({ theme }) => theme.font.color.secondary};
|
|
cursor: pointer;
|
|
display: flex;
|
|
flex-direction: row;
|
|
font-size: ${({ theme }) => theme.font.size.sm};
|
|
gap: ${({ theme }) => theme.spacing(2)};
|
|
justify-content: space-between;
|
|
padding: var(--vertical-padding) var(--horizontal-padding);
|
|
position: relative;
|
|
transition: all 150ms ease;
|
|
transition-property: none;
|
|
user-select: none;
|
|
width: calc(100% - 2 * var(--horizontal-padding));
|
|
&:hover {
|
|
background: ${({ theme }) => theme.background.transparent.light};
|
|
}
|
|
&[data-selected='true'] {
|
|
background: ${({ theme }) => theme.background.tertiary};
|
|
}
|
|
&[data-disabled='true'] {
|
|
color: ${({ theme }) => theme.font.color.light};
|
|
cursor: not-allowed;
|
|
}
|
|
svg {
|
|
height: 16px;
|
|
width: 16px;
|
|
}
|
|
`;
|
|
|
|
export type MenuItemCommandProps = {
|
|
LeftIcon?: IconComponent;
|
|
text: string;
|
|
firstHotKey?: string;
|
|
secondHotKey?: string;
|
|
className?: string;
|
|
isSelected?: boolean;
|
|
onClick?: () => void;
|
|
};
|
|
|
|
export const MenuItemCommand = ({
|
|
LeftIcon,
|
|
text,
|
|
firstHotKey,
|
|
secondHotKey,
|
|
className,
|
|
isSelected,
|
|
onClick,
|
|
}: MenuItemCommandProps) => {
|
|
const theme = useTheme();
|
|
const isMobile = useIsMobile();
|
|
|
|
return (
|
|
<StyledMenuItemCommandContainer
|
|
onClick={onClick}
|
|
className={className}
|
|
isSelected={isSelected}
|
|
>
|
|
<StyledMenuItemLeftContent>
|
|
{LeftIcon && (
|
|
<StyledBigIconContainer>
|
|
<LeftIcon size={theme.icon.size.sm} />
|
|
</StyledBigIconContainer>
|
|
)}
|
|
<StyledMenuItemLabelText hasLeftIcon={!!LeftIcon}>
|
|
{text}
|
|
</StyledMenuItemLabelText>
|
|
</StyledMenuItemLeftContent>
|
|
{!isMobile && (
|
|
<MenuItemCommandHotKeys
|
|
firstHotKey={firstHotKey}
|
|
secondHotKey={secondHotKey}
|
|
/>
|
|
)}
|
|
</StyledMenuItemCommandContainer>
|
|
);
|
|
};
|