Update design for clicking on badges

This commit is contained in:
Evan Hahn 2021-11-18 14:01:53 -06:00 committed by GitHub
parent 80320d8825
commit 1ba48512f6
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 58 additions and 28 deletions

View file

@ -112,12 +112,30 @@
}
&__badge {
pointer-events: none;
position: absolute;
z-index: 1;
// Positioning should be overridden by JavaScript. These are set defensively.
bottom: 0;
right: 0;
&--static {
pointer-events: none;
}
&--button {
background-color: transparent;
background-position: center center;
background-size: contain;
border: 0;
outline: none;
@include keyboard-mode {
&:focus {
outline: 2px solid $color-ultramarine;
border-radius: 6px;
}
}
}
}
}

View file

@ -53,6 +53,7 @@ const createProps = (overrideProps: Partial<Props> = {}): Props => ({
name: text('name', overrideProps.name || ''),
noteToSelf: boolean('noteToSelf', overrideProps.noteToSelf || false),
onClick: action('onClick'),
onClickBadge: action('onClickBadge'),
phoneNumber: text('phoneNumber', overrideProps.phoneNumber || ''),
searchResult: boolean(
'searchResult',

View file

@ -2,6 +2,7 @@
// SPDX-License-Identifier: AGPL-3.0-only
import type {
CSSProperties,
FunctionComponent,
MouseEvent,
ReactChild,
@ -68,6 +69,7 @@ export type Props = {
searchResult?: boolean;
onClick?: (event: MouseEvent<HTMLButtonElement>) => unknown;
onClickBadge?: (event: MouseEvent<HTMLButtonElement>) => unknown;
// Matches Popper's RefHandler type
innerRef?: React.Ref<HTMLDivElement>;
@ -104,6 +106,7 @@ export const Avatar: FunctionComponent<Props> = ({
loading,
noteToSelf,
onClick,
onClickBadge,
sharedGroupNames,
size,
theme,
@ -254,19 +257,35 @@ export const Avatar: FunctionComponent<Props> = ({
badgeTheme
);
if (badgeImagePath) {
badgeNode = (
<img
alt={badge.name}
className="module-Avatar__badge"
src={badgeImagePath}
style={{
const positionStyles: CSSProperties = {
width: badgePlacement.size,
height: badgePlacement.size,
bottom: badgePlacement.bottom,
right: badgePlacement.right,
};
if (onClickBadge) {
badgeNode = (
<button
aria-label={badge.name}
className="module-Avatar__badge module-Avatar__badge--button"
onClick={onClickBadge}
style={{
backgroundImage: `url('${encodeURI(badgeImagePath)}')`,
...positionStyles,
}}
type="button"
/>
);
} else {
badgeNode = (
<img
alt={badge.name}
className="module-Avatar__badge module-Avatar__badge--static"
src={badgeImagePath}
style={positionStyles}
/>
);
}
}
} else if (badge && !theme) {
log.error('<Avatar> requires a theme if a badge is provided');

View file

@ -14,7 +14,6 @@ import { BadgeDialog } from '../BadgeDialog';
import type { BadgeType } from '../../badges/types';
import { SharedGroupNames } from '../SharedGroupNames';
import { ConfirmationDialog } from '../ConfirmationDialog';
import { shouldShowBadges } from '../../badges/shouldShowBadges';
export type PropsDataType = {
areWeAdmin: boolean;
@ -107,13 +106,8 @@ export const ContactModal = ({
theme={theme}
title={contact.title}
unblurredAvatarPath={contact.unblurredAvatarPath}
onClick={() => {
setView(
preferredBadge && shouldShowBadges()
? ContactModalView.ShowingBadges
: ContactModalView.ShowingAvatar
);
}}
onClick={() => setView(ContactModalView.ShowingAvatar)}
onClickBadge={() => setView(ContactModalView.ShowingBadges)}
/>
<div className="ContactModal__name">{contact.title}</div>
<div className="module-about__container">

View file

@ -15,7 +15,6 @@ import type { LocalizerType, ThemeType } from '../../../types/Util';
import { bemGenerator } from './util';
import { BadgeDialog } from '../../BadgeDialog';
import type { BadgeType } from '../../../badges/types';
import { shouldShowBadges } from '../../../badges/shouldShowBadges';
export type Props = {
badges?: ReadonlyArray<BadgeType>;
@ -92,11 +91,10 @@ export const ConversationDetailsHeader: React.ComponentType<Props> = ({
{...conversation}
noteToSelf={isMe}
onClick={() => {
setActiveModal(
preferredBadge && shouldShowBadges()
? ConversationDetailsHeaderActiveModal.ShowingBadges
: ConversationDetailsHeaderActiveModal.ShowingAvatar
);
setActiveModal(ConversationDetailsHeaderActiveModal.ShowingAvatar);
}}
onClickBadge={() => {
setActiveModal(ConversationDetailsHeaderActiveModal.ShowingBadges);
}}
sharedGroupNames={[]}
theme={theme}