Skip to content

Commit

Permalink
Allow for overriding the Item display, specifically so we can disable…
Browse files Browse the repository at this point in the history
… the hover effect
  • Loading branch information
wrandall22 committed Aug 13, 2024
1 parent 7ff6ee4 commit ee836fa
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 3 deletions.
6 changes: 4 additions & 2 deletions src/components/InfiniteList/InfiniteList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ const ListContainer: React.ComponentType<ListProps> = React.forwardRef(
),
);

const ItemWithBorders = styled(ListItem, {
export const ItemWithBorders = styled(ListItem, {
shouldForwardProp: (prop) => prop !== 'disableHover',
})<{ disableHover?: boolean }>(({ disableHover }) => ({
padding: `${padding}px`,
Expand Down Expand Up @@ -67,6 +67,7 @@ const GroupLabel = styled(Typography)(({ theme }) => ({
export interface InfiniteListProps<T, C> {
loading: boolean;
EmptyPlaceholder?: ReactElement | null;
ItemOverride?: React.ComponentType<ItemProps> | null;
itemContent: ItemContent<T, C>;
// eslint-disable-next-line @typescript-eslint/no-explicit-any
context?: any;
Expand All @@ -78,6 +79,7 @@ export const InfiniteList = <T, C>({
loading,
data = [],
EmptyPlaceholder = null,
ItemOverride = null,
context,
groupBy,
itemContent,
Expand All @@ -103,7 +105,7 @@ export const InfiniteList = <T, C>({
Footer: loading ? Loading : undefined,
EmptyPlaceholder: loading ? undefined : () => EmptyPlaceholder,
List: ListContainer,
Item,
Item: ItemOverride ?? Item,
ScrollSeekPlaceholder: SkeletonItem,
...props.components,
},
Expand Down
11 changes: 10 additions & 1 deletion src/components/Tool/FixEmailAddresses/FixEmailAddresses.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,12 @@ import {
import { styled } from '@mui/material/styles';
import { useSnackbar } from 'notistack';
import { Trans, useTranslation } from 'react-i18next';
import { ItemProps } from 'react-virtuoso';
import { SetContactFocus } from 'pages/accountLists/[accountListId]/tools/useToolsHelper';
import { InfiniteList } from 'src/components/InfiniteList/InfiniteList';
import {
InfiniteList,
ItemWithBorders,
} from 'src/components/InfiniteList/InfiniteList';
import { navBarHeight } from 'src/components/Layouts/Primary/Primary';
import {
PersonInvalidEmailFragment,
Expand Down Expand Up @@ -93,6 +97,10 @@ const DefaultSourceWrapper = styled(Box)(({ theme }) => ({
},
}));

const ItemOverride: React.ComponentType<ItemProps> = (props) => (
<ItemWithBorders disableGutters disableHover={true} {...props} />
);

export interface EmailAddressData {
id: string;
primary: boolean;
Expand Down Expand Up @@ -400,6 +408,7 @@ export const FixEmailAddresses: React.FC<FixEmailAddressesProps> = ({
width: '100%',
scrollbarWidth: 'none',
}}
ItemOverride={ItemOverride}
></InfiniteList>
<Grid item xs={12}>
<Box width="100%" display="flex" justifyContent="center">
Expand Down

0 comments on commit ee836fa

Please sign in to comment.