You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
session-desktop/ts/components/leftpane/overlay/choose-action/ContactRow.tsx

91 lines
2.5 KiB
TypeScript

import { useDispatch } from 'react-redux';
import styled, { CSSProperties } from 'styled-components';
import { useAvatarPath } from '../../../../hooks/useParamSelector';
import { openConversationWithMessages } from '../../../../state/ducks/conversations';
import { updateUserDetailsModal } from '../../../../state/ducks/modalDialog';
import { Avatar, AvatarSize } from '../../../avatar/Avatar';
type Props = { id: string; displayName?: string; style: CSSProperties };
const StyledAvatarItem = styled.div`
padding-right: var(--margins-sm);
`;
const AvatarItem = (props: Pick<Props, 'displayName' | 'id'>) => {
const { id, displayName } = props;
const avatarPath = useAvatarPath(id);
const dispatch = useDispatch();
function onPrivateAvatarClick() {
dispatch(
updateUserDetailsModal({
conversationId: id,
userName: displayName || '',
authorAvatarPath: avatarPath,
})
);
}
return (
<StyledAvatarItem>
<Avatar size={AvatarSize.S} pubkey={id} onAvatarClick={onPrivateAvatarClick} />
</StyledAvatarItem>
);
};
const StyledContactRowName = styled.div`
color: var(--text-primary-color);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
font-size: var(--font-size-lg);
`;
const StyledRowContainer = styled.button`
display: flex;
align-items: center;
padding: 0 var(--margins-lg);
transition: background-color var(--default-duration) linear;
cursor: pointer;
&:hover {
background-color: var(--conversation-tab-background-hover-color);
}
`;
const StyledBreak = styled.div`
display: flex;
align-items: center;
padding: 0 var(--margins-lg);
color: var(--text-secondary-color);
font-size: var(--font-size-sm);
height: var(--contact-row-break-width);
`;
export const ContactRowBreak = (props: { char: string; key: string; style: CSSProperties }) => {
const { char, key, style } = props;
return (
<StyledBreak key={key} style={style}>
{char}
</StyledBreak>
);
};
export const ContactRow = (props: Props) => {
const { id, style, displayName } = props;
return (
<StyledRowContainer
style={style}
// eslint-disable-next-line @typescript-eslint/no-misused-promises
onClick={async () => openConversationWithMessages({ conversationKey: id, messageId: null })}
>
<AvatarItem id={id} displayName={displayName} />
<StyledContactRowName data-testid="module-conversation__user__profile-name">
{displayName || id}
</StyledContactRowName>
</StyledRowContainer>
);
};