Statements | Branches | Functions | Lines |
---|---|---|---|
🤡 A React component for rendering MetaMask avatars based on account address
The MetaMaskAvatar
component is a React functional component that takes in a required address
property of type string
and an optional size
property of type number
. It returns an image avatar of the given Ethereum address provided as a string and renders it within an AvatarWrapper
component, which can be styled using the className
property.
Hosted storybook
npm install react-metamask-avatar
yarn add react-metamask-avatar
The required address property is a string of length 42 that represents an Ethereum address. If it is not provided or does not meet the expected length, the component returns null.
The optional size property is a number that sets the size of the avatar image in pixels. If not provided, it defaults to 24.
The optional className property is a string that allows for custom styling using the AvatarWrapper component. It will be added to the className prop of the AvatarWrapper component.
import React from 'react';
import { MetaMaskAvatar } from 'react-metamask-avatar';
export const App: React.FunctionComponent = () => {
return (
<MetaMaskAvatar address="0xb01F14d1C9000D453241221EB54648F1C378c970" size={24} />
)
}
Under the hood react-metamask-avatar
uses @emotion/styled
. Therefore, following a guide
for custom styling emotion elements is the way to go.
Example:
import React from 'react';
import styled from '@emotion/styled';
import { MetaMaskAvatar } from 'react-metamask-avatar';
const SquareMetaMaskAvatar = styled(MetaMaskAvatar)`
border-radius: none;
`;
export const App: React.FunctionComponent = () => {
return (
<SquareMetaMaskAvatar address="0xb01F14d1C9000D453241221EB54648F1C378c970" size={24} />
)
}