mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
ff96836871
* Add updated version of the Snaps list UI Add more changes to match the designs of snaps list Add next design iteration for snaps list Update icons, sizes and pointer behaviour Add redesign for snap settings page Refactor and improve designs Fix unit tests and refactor code Fix e2e test Fix lint Update margin values Add CSS override for connected sites list and update margins Update paddings as requested Fix vertical alignment of links Fix tooltip position on the enable button Add usage of getSnapName function for displaying snap names Fix e2e tests and update date format for snap install date Improve unit test for snap-settings-card Change installation info logic Update mocked state for snap Add tests for ViewSnap component, refactor and update mocked state Add check for version info Change Snaps icon in Settings Refactor Snaps list to use selector Add handling in case of missing version history * Fix icon ref * Remove console logs * Remove onClick from selector * Add code fencing for imports in selectors.js
82 lines
1.9 KiB
JavaScript
82 lines
1.9 KiB
JavaScript
import React from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import classnames from 'classnames';
|
|
import { useSelector } from 'react-redux';
|
|
import {
|
|
TextColor,
|
|
IconColor,
|
|
AlignItems,
|
|
DISPLAY,
|
|
JustifyContent,
|
|
Size,
|
|
} from '../../../../helpers/constants/design-system';
|
|
import { getSnapName } from '../../../../helpers/utils/util';
|
|
import {
|
|
AvatarFavicon,
|
|
BadgeWrapper,
|
|
BadgeWrapperPosition,
|
|
AvatarIcon,
|
|
AvatarBase,
|
|
IconName,
|
|
IconSize,
|
|
} from '../../../component-library';
|
|
import { getTargetSubjectMetadata } from '../../../../selectors';
|
|
|
|
const SnapAvatar = ({ snapId, className }) => {
|
|
const subjectMetadata = useSelector((state) =>
|
|
getTargetSubjectMetadata(state, snapId),
|
|
);
|
|
|
|
const friendlyName = snapId && getSnapName(snapId, subjectMetadata);
|
|
|
|
const iconUrl = subjectMetadata?.iconUrl;
|
|
|
|
const fallbackIcon = friendlyName && friendlyName[0] ? friendlyName[0] : '?';
|
|
|
|
return (
|
|
<BadgeWrapper
|
|
className={classnames('snap-avatar', className)}
|
|
badge={
|
|
<AvatarIcon
|
|
iconName={IconName.Snaps}
|
|
size={IconSize.Xs}
|
|
backgroundColor={IconColor.infoDefault}
|
|
iconProps={{
|
|
size: IconSize.Xs,
|
|
color: IconColor.infoInverse,
|
|
}}
|
|
/>
|
|
}
|
|
position={BadgeWrapperPosition.bottomRight}
|
|
>
|
|
{iconUrl ? (
|
|
<AvatarFavicon size={Size.LG} src={iconUrl} name={friendlyName} />
|
|
) : (
|
|
<AvatarBase
|
|
size={Size.LG}
|
|
display={DISPLAY.FLEX}
|
|
alignItems={AlignItems.center}
|
|
justifyContent={JustifyContent.center}
|
|
color={TextColor.textAlternative}
|
|
style={{ borderWidth: '0px' }}
|
|
>
|
|
{fallbackIcon}
|
|
</AvatarBase>
|
|
)}
|
|
</BadgeWrapper>
|
|
);
|
|
};
|
|
|
|
SnapAvatar.propTypes = {
|
|
/**
|
|
* The id of the snap
|
|
*/
|
|
snapId: PropTypes.string,
|
|
/**
|
|
* The className of the SnapAvatar
|
|
*/
|
|
className: PropTypes.string,
|
|
};
|
|
|
|
export default SnapAvatar;
|