Closes https://github.com/twentyhq/core-team-issues/issues/253 and https://github.com/twentyhq/core-team-issues/issues/256. - Created `CommandMenuList`, a component used at the root level of the command menu and inside the search page of the command menu - Refactored record agnostic actions - Added shortcuts to the action menu entries (`/` key for the search) and updated the design of the shortcuts - Reordered actions at the root level of the command menu https://github.com/user-attachments/assets/e1339cc4-ef5d-45c5-a159-6817a54b92e9
56 lines
1.3 KiB
TypeScript
56 lines
1.3 KiB
TypeScript
import { isNonEmptyString } from '@sniptt/guards';
|
|
import { useRecoilValue } from 'recoil';
|
|
import { IconArrowUpRight, IconComponent, MenuItemCommand } from 'twenty-ui';
|
|
|
|
import { useCommandMenuOnItemClick } from '@/command-menu/hooks/useCommandMenuOnItemClick';
|
|
import { useSelectableList } from '@/ui/layout/selectable-list/hooks/useSelectableList';
|
|
import { ReactNode } from 'react';
|
|
|
|
export type CommandMenuItemProps = {
|
|
label: string;
|
|
to?: string;
|
|
id: string;
|
|
onClick?: () => void;
|
|
Icon?: IconComponent;
|
|
hotKeys?: string[];
|
|
shouldCloseCommandMenuOnClick?: boolean;
|
|
RightComponent?: ReactNode;
|
|
};
|
|
|
|
export const CommandMenuItem = ({
|
|
label,
|
|
to,
|
|
id,
|
|
onClick,
|
|
Icon,
|
|
hotKeys,
|
|
shouldCloseCommandMenuOnClick,
|
|
RightComponent,
|
|
}: CommandMenuItemProps) => {
|
|
const { onItemClick } = useCommandMenuOnItemClick();
|
|
|
|
if (isNonEmptyString(to) && !Icon) {
|
|
Icon = IconArrowUpRight;
|
|
}
|
|
|
|
const { isSelectedItemIdSelector } = useSelectableList();
|
|
const isSelectedItemId = useRecoilValue(isSelectedItemIdSelector(id));
|
|
|
|
return (
|
|
<MenuItemCommand
|
|
LeftIcon={Icon}
|
|
text={label}
|
|
hotKeys={hotKeys}
|
|
onClick={() =>
|
|
onItemClick({
|
|
shouldCloseCommandMenuOnClick,
|
|
onClick,
|
|
to,
|
|
})
|
|
}
|
|
isSelected={isSelectedItemId}
|
|
RightComponent={RightComponent}
|
|
/>
|
|
);
|
|
};
|