1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-06 00:07:44 +01:00
unleash.unleash/frontend/src/component/commandBar/CommandPages.tsx

65 lines
2.0 KiB
TypeScript
Raw Normal View History

import { usePlausibleTracker } from 'hooks/usePlausibleTracker';
import { Link } from 'react-router-dom';
import {
CommandResultGroup,
StyledButtonTypography,
StyledListItemIcon,
StyledListItemText,
listItemButtonStyle,
type CommandResultGroupItem,
} from './RecentlyVisited/CommandResultGroup';
import { ListItemButton } from '@mui/material';
import { IconRenderer } from 'component/layout/MainLayout/NavigationSidebar/IconRenderer';
export const CommandPages = ({
items,
onClick,
}: {
items: CommandResultGroupItem[];
onClick: () => void;
}) => {
const { trackEvent } = usePlausibleTracker();
const groupName = 'Pages';
const onItemClick = (item: CommandResultGroupItem) => {
trackEvent('command-bar', {
props: {
eventType: `click`,
source: 'search',
eventTarget: groupName,
...(groupName === 'Pages' && { pageType: item.name }),
},
});
onClick();
};
return (
<CommandResultGroup
groupName={'Pages'}
icon={'default'}
onClick={onClick}
>
{items.map((item, index) => (
<ListItemButton
key={`command-result-group-pages-${index}`}
dense={true}
component={Link}
to={item.link}
onClick={() => {
onItemClick(item);
}}
sx={listItemButtonStyle}
>
<StyledListItemIcon>
<IconRenderer path={item.link} />
</StyledListItemIcon>
<StyledListItemText>
<StyledButtonTypography color='textPrimary'>
{item.name}
</StyledButtonTypography>
</StyledListItemText>
</ListItemButton>
))}
</CommandResultGroup>
);
};